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

Envío 2550

Problema 0xde - Ordenar un arreglo grande

  • Autor: pipelin1010
  • Fecha: 2021-01-03 07:57:22 UTC (Hace alrededor de 4 años)
Caso # Resultado Tiempo Memoria
#1
Incorrecto
0.007 s 27 KBi
#2
Correcto
0.005 s 2 KBi
#3
Incorrecto
0.005 s 2 KBi
#4
Correcto
0.006 s 2 KBi
#5
Correcto
0.007 s 2 KBi
#6
Correcto
0.006 s 33 KBi
#7
Tiempo límite excedido
1.039 s 2 KBi
#8
Tiempo límite excedido
1.046 s 2 KBi
#9
Tiempo límite excedido
1.096 s 5 KBi
#10
Tiempo límite excedido
0.576 s 2 KBi
#11
Tiempo límite excedido
1.046 s 2 KBi
#12
Tiempo límite excedido
1.025 s 2 KBi
#13
Correcto
0.075 s 2 KBi
#14
Incorrecto
0.054 s 2 KBi
#15
Incorrecto
0.058 s 2 KBi
#16
Incorrecto
0.073 s 3 KBi
#17
Incorrecto
0.077 s 3 KBi
#18
Correcto
0.054 s 2 KBi
#19
Correcto
0.058 s 2 KBi
#20
Tiempo límite excedido
0.595 s 1 KBi
#21
Incorrecto
0.061 s 2 KBi
#22
Incorrecto
0.062 s 3 KBi
#23
Incorrecto
0.061 s 2 KBi
#24
Incorrecto
0.082 s 2 KBi
#25
Incorrecto
0.058 s 2 KBi
#26
Incorrecto
0.062 s 3 KBi
#27
Incorrecto
0.053 s 2 KBi
Puntos totales: 26 / 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 indPivot = (rand()%(r-l+1))+l;
    //cout << "IND PIVOT " << indPivot << "\n";
    int pivot = a[indPivot];
    int p = l;
    for(int i = l+1; i <= r; i++){
        if(pivot >= a[i]){
            swap(a[++p],a[i]);
        }
        // forn(i,n) cout << a[i] << " ";
        // cout << "\n";
    }
    // forn(i,n) cout << a[i] << " ";
    // cout << "\n";
    // cout << "P " << p << "\n";
    // p--;
    swap(a[p],a[indPivot]);
    if (l < (p-1))
        quick(l,p-1);
    if ((p+1) < r)
        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;
}