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);

}

}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值