我是靠谱客的博主 动人芒果,最近开发中收集的这篇文章主要介绍分治---快速排序,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

数组排序任务可以如下完成:

1)设k=a[0], 将k挪到适当位置,使得比k小的元素都在k左边,比k大的元素都在k右边,和k相等的,不关心在k左右出现均可 (O(n)时间完成)

2) 把k左边的部分快速排序

3) 把k右边的部分快速排序

#include <iostream>
using namespace std;
void swap(int & a,int & b) //交换变量a,b值
{
	int tmp = a;
	a = b;
	b = tmp;
}
void QuickSort(int a[],int s,int e)
{
	if( s >= e)
		return;
	int k = a[s];
	int i = s,j = e;
	while( i != j )
	{
		while( j > i && a[j] >= k )
			--j;
		swap(a[i],a[j]);
		while( i < j && a[i] <= k )
			++i;
		swap(a[i],a[j]);
	}	 //处理完后,a[i] = k
	QuickSort(a,s,i-1);
	QuickSort(a,i+1,e);
}
int a[] = { 93,27,30,2,8,12,2,8,30,89};
int main()
{
	int size = sizeof(a)/sizeof(int);
	QuickSort(a,0,size-1);
	for(int i = 0;i < size; ++i)
		cout << a[i] << ",";
	cout << endl;
	return 0;
}


最后

以上就是动人芒果为你收集整理的分治---快速排序的全部内容,希望文章能够帮你解决分治---快速排序所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(44)

评论列表共有 0 条评论

立即
投稿
返回
顶部