█████████ ████ ███░░░░░███ ░░███ ███ ░░░ ██████ ███████ ██████ ██████ ░███ ███░░███ ███░░███ ███░░███ ███░░███ ░███ ░███ ░███░███ ░███ ░███████ ░███ ░███ ░░███ ███░███ ░███░███ ░███ ░███░░░ ░███ ░███ ░░█████████ ░░██████ ░░████████░░██████ ░░██████ ░░░░░░░░░ ░░░░░░ ░░░░░░░░ ░░░░░░ ░░░░░░

Envío 6089

Problema 0xde - Ordenar un arreglo grande

Caso # Resultado Tiempo Memoria
#1
Correcto
0.005 s 1 KBi
#2
Correcto
0.003 s 1 KBi
#3
Correcto
0.006 s 0 KBi
#4
Correcto
0.002 s 0 KBi
#5
Correcto
0.002 s 0 KBi
#6
Correcto
0.002 s 0 KBi
#7
Tiempo límite excedido
1.07 s 1 KBi
#8
Tiempo límite excedido
1.098 s 3 KBi
#9
Tiempo límite excedido
1.06 s 3 KBi
#10
Correcto
0.226 s 3 KBi
#11
Tiempo límite excedido
1.083 s 3 KBi
#12
Tiempo límite excedido
1.045 s 2 KBi
#13
Tiempo límite excedido
1.073 s 2 KBi
#14
Tiempo límite excedido
1.057 s 1 KBi
#15
Tiempo límite excedido
1.061 s 1 KBi
#16
Correcto
0.031 s 3 KBi
#17
Correcto
0.057 s 3 KBi
#18
Tiempo límite excedido
1.07 s 2 KBi
#19
Tiempo límite excedido
1.065 s 2 KBi
#20
Tiempo límite excedido
1.023 s 2 KBi
#21
Tiempo límite excedido
1.078 s 1 KBi
#22
Tiempo límite excedido
1.059 s 1 KBi
#23
Tiempo límite excedido
1.069 s 1 KBi
#24
Tiempo límite excedido
1.1 s 2 KBi
#25
Tiempo límite excedido
1.099 s 2 KBi
#26
Tiempo límite excedido
1.045 s 2 KBi
#27
Tiempo límite excedido
1.099 s 1 KBi
Puntos totales: 34 / 100

Código

#include <bits/stdc++.h>
using namespace std;

int partition(int* arr, int l, int r){
    int p = arr[r];
    int i = l - 1;

    for(int j=l; j<r; j++){
        if(arr[j] < p){
            i++;
            swap(arr[i], arr[j]);
        }
    }
    swap(arr[i+1], arr[r]);
    return i + 1;
}

void quickSort(int* arr, int l, int r){
    if(l >= r || l < 0) return;

    int p = partition(arr, l, r);

    quickSort(arr, l, p-1);
    quickSort(arr, p+1, r);
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL); 
    // your code goes here
    int N, i;
    cin >> N;
    int arr[N];

    for(i=0; i<N; i++){
        cin >> arr[i];
    }

    quickSort(arr, 0, N-1);

    for(i=0; i<N; i++){
        cout << arr[i] << " ";
    }

    cout << "\n";
    
	return 0;
}