Caso # | Resultado | Tiempo | Memoria |
---|---|---|---|
#1 |
Correcto
|
0.006 s | 1 KBi |
#2 |
Correcto
|
0.006 s | 1 KBi |
#3 |
Correcto
|
0.008 s | 1 KBi |
#4 |
Correcto
|
0.006 s | 1 KBi |
#5 |
Correcto
|
0.005 s | 2 KBi |
#6 |
Correcto
|
0.007 s | 1 KBi |
#7 |
Correcto
|
0.153 s | 3 KBi |
#8 |
Correcto
|
0.156 s | 3 KBi |
#9 |
Correcto
|
0.153 s | 3 KBi |
#10 |
Correcto
|
0.203 s | 2 KBi |
#11 |
Correcto
|
0.18 s | 3 KBi |
#12 |
Correcto
|
0.149 s | 2 KBi |
#13 |
Correcto
|
0.156 s | 3 KBi |
#14 |
Correcto
|
0.15 s | 2 KBi |
#15 |
Correcto
|
0.156 s | 3 KBi |
#16 |
Correcto
|
0.185 s | 3 KBi |
#17 |
Correcto
|
0.203 s | 3 KBi |
#18 |
Correcto
|
0.144 s | 3 KBi |
#19 |
Correcto
|
0.209 s | 3 KBi |
#20 |
Correcto
|
0.197 s | 2 KBi |
#21 |
Correcto
|
0.156 s | 2 KBi |
#22 |
Correcto
|
0.169 s | 3 KBi |
#23 |
Correcto
|
0.152 s | 3 KBi |
#24 |
Correcto
|
0.15 s | 3 KBi |
#25 |
Correcto
|
0.193 s | 3 KBi |
#26 |
Correcto
|
0.152 s | 2 KBi |
#27 |
Correcto
|
0.153 s | 3 KBi |
// #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, sol; //Quick sort void quick(int l, int r){ bool equal = true; forr(i,l,r){ if(a[i] != a[i+1]){ equal = false; } } if(equal) return; if(l >= r) return; int indPivot = (rand()%(r-l+1))+l; swap(a[l],a[indPivot]); int pivot = a[l]; int p = l; for(int i = l+1; i <= r; i++){ if(pivot >= a[i]){ swap(a[++p],a[i]); } } swap(a[p],a[l]); quick(l,p-1); quick(p+1,r); } vi merge(int l, int r){ // cout << "NOW ON L " << l << " R " << r << "\n"; int mid = (l+r)/2; int size = (r-l+1); vi arrL, arrR, arr; if (l == r){ arr.assign(1,a[l]); // cout << "AFTER MERGE L " << l << " R " << r << "\n"; // forn(i,(int)arr.size()) cout << arr[i] << " "; // cout << "\n"; return arr; } arrL = merge(l,mid); arrR = merge(mid+1,r); arr.assign(size,0); for(int i = 0, j = 0, k = 0; k < size; k++){ if(i >= (int)arrL.size()){ arr[k] = arrR[j]; j++; }else if(j >= (int)arrR.size()){ arr[k] = arrL[i]; i++; }else if(arrL[i] < arrR[j]){ arr[k] = arrL[i]; i++; }else{ arr[k] = arrR[j]; j++; } } // cout << "AFTER MERGE L " << l << " R " << r << "\n"; // forn(i,(int)arr.size()) cout << arr[i] << " "; // cout << "\n"; return arr; } int main(){ //freopen("out","w",stdout); ios::sync_with_stdio(0); cin >> n; a.assign(n,0); forn(i,n) cin >> a[i]; //quick(0,n-1); a = merge(0,n-1); cout << a[0]; forr(i,1,n){ cout << " " << a[i]; } cout << "\n"; return 0; }