排序算法-----快速排序简单介绍

快速排序的思想就是采用分治的思想,先选定一个比较的基准元素,一般选择数组中的第一个元素,然后分别以最左边的元素,下标为0和最右边的元素下标为n-1,分别从左边和右边依次用下标从中间靠拢,期间分别与基准元素比较,如果分别比之小和比之大,则下标移动,否则两者都停止,交换元素,继续,这趟循环直到下标大小相同,随后便将基准元素放入到最终下标位置处,这便是其中的一次循环,经过这次循环,左子列的数都比这个基准元素小,右子列的数都比这个基准元素的数大,以后就可以用这个规律采用递归分别排序这个基准元素左边的左子列和右边的右子列。




void quick_sort(int a[],int left,int right)

{

int  l = left,r = right,temp;

while(l<r)

{

pivot = a[(left+right)/2];

while(a[l]<pivot)

i++;

while(a[j]>pivot)

j--;

if(i>=j)

break;

temp = a[i];

a[i] = a[j];

a[j] = temp;

l++;

r--;

}

if(l== r)

l++;

if(left<r)

quick_sort(a,left,l-1);

if(l<right)

quick_sort(a,l+1,right);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孙仲谋111

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值