Cod sursa(job #2743868)

Utilizator Liviu_Ionut_MoantaMoanta Ionut Liviu Liviu_Ionut_Moanta Data 23 aprilie 2021 16:43:59
Problema Sortare prin comparare Scor 80
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.45 kb
#include<fstream>
#include<algorithm>
#include<cmath>
using namespace std;
ifstream fin("algsort.in");
ofstream fout("algsort.out");
int v[500005];
int n,m,i,j,k,maxim,s,sum,p,u,aux;
void quicksort(int i,int j){
    if(i>=j)
        return;
    int ok;
    int t=i;
    int u=j;
    int poz=i;
    while(t<u){
        if(poz==t){
            ok=0;
            for(int g=u;g>=t;g--){
                if(v[g]<v[t]){
                    swap(v[g],v[t]);
                    u=g;
                    poz=u;
                    t++;
                    ok=1;
                    break;
                }
            }
            if(ok==0){
                poz=t;
                u=poz;
            }
        }
        else{
            ok=0;
            for(int g=t;g<=u;g++){
                if(v[g]>v[u]){
                    swap(v[g],v[u]);
                    t=g;
                    poz=t;
                    u--;
                    ok=1;
                    break;
                }
            }
            if(ok==0){
                poz=u;
                t=poz;
            }
        }
    }
    quicksort(i,poz-1);
    quicksort(poz+1,j);
}
int main(){
    fin>>n;
    for(i=1;i<=n;i++){
        fin>>v[i];
    }
    for(i=1;i<=n;i++){
        k=1+rand()%n;
        aux=v[i];
        v[i]=v[k];
        v[k]=aux;

    }
    quicksort(1,n);
    for(i=1;i<=n;i++)
        fout<<v[i]<<" ";
    return 0;
}