Qsort-快排

void quicksort(int *left,int * right){

 

inttmp=*left;

int*first=left;

int*last=right;

while(left!=right){

while(left!=right&&tmp<*right)right--;

*left=*right;

while(left!=right&&tmp>*right)left++;

*right=*left;

}

*left=tmp;

quicksort(first,left-1);

quicksort(left+1,last);

 

}

 

int main(char **argv){

 

int* arr=new int[10];

 

arr[0]=32;

arr[1]=22;

arr[2]=4;

arr[3]=6;

arr[4]=2;

arr[5]=8;

arr[6]=10;

arr[7]=11;

arr[8]=34;

arr[9]=12;

 

quicksort(&arr[0],&arr[9]);

return0;

}



Qsort-快排(单向遍历)


void swap(int *c, int* d){

     int e;

     e = *c;

     *c = *d;

     *d = e;

}

 

intpartition(int a[],int p,int r){

    int x,i,j;

    x = a[r];

    i = p - 1;

    for(j=p; j<=r-1; j++){

             if(a[j] < x){

                    i++;

                    swap(&a[i],&a[j]);

             }

    }

    swap(&a[i+1],&a[r]);

    return i+1;

}

 

void quickSort(int a[],int p, int r){

     int q;

     if(p < r){

         q = partition(a,p,r);

          quickSort(a,p,q-1);

          quickSort(a,q+1,r);

     }

}



你可能感兴趣的:(Qsort-快排)