概述
#include <stdio.h>
int a[101],n;
void quick_sort(int left,int right)
{
int i,j,t,temp;
if(left>=right)
return;
temp=a[left];
i=left;
j=right;
//在哨兵i,j 会合之前,将右侧找到的小数与左边找到的大数 互换
while(i!=j)
{
while(a[j]>=temp&&i>j)//在没有找到小数前 (j--) 继续 “往下”找
j--;
while(a[i]<=temp&&i>j)//在没有找到大数前(i++) 继续“往上”找
i++;
//在右侧找到一个小数且左侧找到一个大数后,将两个数的位置对调
if(i<j)
{
t=a[i];
a[i]=a[j];
a[j]=t;
}
}
//在哨兵i,j会合,将a[i]调到最前面,然后将temp归位
a[left]=a[i];
a[i]=temp;
quick_sort(left,i-1);
quick_sort(i+1,right) ;
return;
}
int main()
{
}
最后
以上就是轻松月饼为你收集整理的数据结构和算法——快速排序的全部内容,希望文章能够帮你解决数据结构和算法——快速排序所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复