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

Envío 2436

Problema 0xde - Ordenar un arreglo grande

  • Autor: pipelin1010
  • Fecha: 2020-12-18 15:52:55 UTC (Hace alrededor de 4 años)
Caso # Resultado Tiempo Memoria
#1
Correcto
0.006 s 2 KBi
#2
Correcto
0.007 s 1 KBi
#3
Correcto
0.005 s 1 KBi
#4
Correcto
0.007 s 2 KBi
#5
Correcto
0.007 s 1 KBi
#6
Correcto
0.005 s 2 KBi
#7
Tiempo límite excedido
1.033 s 2 KBi
#8
Tiempo límite excedido
1.032 s 2 KBi
#9
Tiempo límite excedido
1.007 s 1 KBi
#10
Tiempo límite excedido
1.084 s 2 KBi
#11
Tiempo límite excedido
1.084 s 2 KBi
#12
Tiempo límite excedido
1.063 s 1 KBi
#13
Tiempo límite excedido
1.044 s 1 KBi
#14
Tiempo límite excedido
1.073 s 2 KBi
#15
Tiempo límite excedido
1.009 s 1 KBi
#16
Incorrecto
0.077 s 2 KBi
#17
Incorrecto
0.087 s 2 KBi
#18
Tiempo límite excedido
1.066 s 1 KBi
#19
Tiempo límite excedido
1.007 s 2 KBi
#20
Tiempo límite excedido
0.958 s 1 KBi
#21
Tiempo límite excedido
1.056 s 2 KBi
#22
Tiempo límite excedido
1.011 s 2 KBi
#23
Tiempo límite excedido
1.054 s 2 KBi
#24
Tiempo límite excedido
1.029 s 1 KBi
#25
Tiempo límite excedido
1.076 s 2 KBi
#26
Tiempo límite excedido
1.1 s 2 KBi
#27
Tiempo límite excedido
1.062 s 2 KBi
Puntos totales: 23 / 100

Código

//
#include <bits/stdc++.h>
using namespace std;
#define INF 1000000000
#define MOD 1000000007
#define PI 3.14159265
#define EPS 1e-9
#define Pi acos(-1.0)
typedef pair<int, int> ii;
typedef long long ll;
typedef vector<ll> vll;
typedef pair<ll,ll> pll;
#define forr(i,a,b) for(int i=(a); i<(b); i++)
#define clean(arr,val) memset(arr,val,sizeof(arr))
#define forn(i,n) forr(i,0,n)
#define PB push_back
typedef vector<int> vi;
typedef vector<ii> vii;
typedef vector<pll> vpll;

/*CODE START HERE*/

int n;
vi a;

//Quick sort
void quick(int l, int r){
    // cout << "BEGINNING L " << l << " R " << r << "\n";
    // forn(i,n) cout << a[i] << " ";
    // cout << "\n";
    if(l >= r)
        return;
    int pivot = a[l];
    int p = l;
    for(int i = l+1; i <= r; i++){
        if(pivot >= a[i]){
            swap(a[p],a[i]);
            p++;
            //cout << "IN\n";
        }
        // forn(i,n) cout << a[i] << " ";
        // cout << "\n";
    }
    // forn(i,n) cout << a[i] << " ";
    // cout << "\n";
    quick(l,p-1);
    quick(p+1,r);
}

int main(){
    ios::sync_with_stdio(0);
    cin >> n;
    a.assign(n,0);
    forn(i,n) cin >> a[i];
    quick(0,n-1);
    cout << a[0];
    forr(i,1,n){
        cout << " " << a[i];
    }
    cout << "\n";
    return 0;
}