快速排序,是对冒泡排序的一种改进,用该方法对一组序列进行快速,程序怎么写?(用C++)高手帮忙啊…
答案:2 悬赏:10 手机版
解决时间 2021-07-31 15:27
- 提问者网友:火车头
- 2021-07-30 18:45
快速排序,是对冒泡排序的一种改进,用该方法对一组序列进行快速,程序怎么写?(用C++)高手帮忙啊…
最佳答案
- 五星知识达人网友:傲气稳了全场
- 2021-07-30 19:12
void quick_sort(int a[],int s,int e)
{int i,j,t;
if(s<e)
{i=s;j=e;t=a[s];
while(i!=j)
{while (i<j&&a[j]>t) j--;
if (i<j) a[i++]=a[j];
while(i<j&&a[i]<=t) i++;
if(i<j) a[j--]=a[i];
}
a[i]=t;
quick_sort(a,s,i-1);
quick_sort(a,i+1,e);
}
}
快速排序的时间复杂度是O(n*㏒2n),是不稳定的排序
全部回答
- 1楼网友:爱难随人意
- 2021-07-30 19:32
// 快速排序
// 使用递归调用来实现快速排序
// 10/21/2007
// Author: eman lee
#include <stdio.h>
void quick_sort(int data[], int low, int high)
{
int i, j, pivot;
if (low < high)
{
pivot=data[low];
i=low;
j=high;
while(i<j)
{
while (i<j && data[j]>=pivot)
j--;
if(i<j)
data[i++]=data[j]; //将比枢轴记录小的记录移到低端
while (i<j && data[i]<=pivot)
i++;
if(i<j)
data[j--]=data[i]; //将比枢轴记录大的记录移到高端
}
data[i]=pivot; //枢轴记录移到最终位置
quick_sort(data,low,i-1);
quick_sort(data,i+1,high);
}
}
void main()
{
int i;
int data[9] = {54,38,96,23,15,72,60,45,83};
for(i=0;i<9;i++)
{
printf(" %d ",data[i]);
}
printf("\n");
quick_sort(data, 0, 8);
for(i=0;i<9;i++)
{
printf(" %d ",data[i]);
}
}
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯