0005算法笔记——【分治法】快速排序

      1、未优化的快速排序 

      快速排序的基本思想是通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列

   程序清单如下:

//2d8-1 未优化的快速排序
#include "stdafx.h"
#include      
using namespace std; 

int a[] = {5,7,3,4,8,6,9,1,2};

template 
void Swap(Type &x,Type &y);

template 
int Partition(Type a[],int p,int r);

template 
void QuickSort(Type a[],int p,int r);

int main()
{
	for(int i=0; i<9; i++)
	{
		cout<
void Swap(Type &x,Type &y)
{
	Type temp = x;
	x = y;
	y = temp;
}

template 
int Partition(Type a[],int p,int r)
{
	int i = p,j = r + 1;
	Type x = a[p];

	while(true)
	{
		while(a[++i]x);
		if(i>=j)
		{
			break;
		}
		Swap(a[i],a[j]);
	}
	a[p] = a[j];
	a[j] = x;
	return j;
}

template 
void QuickSort(Type a[],int p,int r)
{
	if(p

      程序解释:第48、49行下标j逐渐减小,i逐渐增大,直到a[i]>=x>=a[j]。第50行若i 第56行与第57行 :由于while(a[--j]>x);执行后, j会多减一下 ,最后指向a[j]会小于x, 这时候将a[p]的值与a[j]交换刚好满足左侧都比x小,右侧都比x大

   2、随机后标记元素后的快速排序

   未随机化处理的快速排序最坏情况发生在划分过程产生的两个区域分别包含n-1个元素和1个元素的时候。由于函数Partition的计算时间为O(n),所以如果算法Partition的每一步都出现这种不对称划分,则T(n)=O(n^2)。

   在最好情况下,每次划分所取的基准都恰好为中值,即每次划分都产生两个大小为n/2的区域。此时T(n)=O(nlogn)。

   因此,快速排序算法的性能取决于划分的对称性修改Partition,可以设计出采用随机选择策略的快速排序算法。在快速排序算法的每一步中,当数组还没有被划分时,可以在a[p:r]中随机选择一个元素作为划分基准。

   程序如下:

//2d8-2 随机后标记元素后的快速排序
#include "stdafx.h"
#include  
#include 
using namespace std; 

int a[] = {5,7,3,4,8,6,9,1,2};

template 
void Swap(Type &x,Type &y);

inline int Random(int x, int y);

template 
int Partition(Type a[],int p,int r);

template
int RandomizedPartition(Type a[],int p,int r);

template 
void RandomizedQuickSort(Type a[],int p,int r);

int main()
{
	for(int i=0; i<9; i++)
	{
		cout<
void Swap(Type &x,Type &y)
{
	Type temp = x;
	x = y;
	y = temp;
}

inline int Random(int x, int y)
{
     srand((unsigned)time(0));
     int ran_num = rand() % (y - x) + x;
     return ran_num;
}

template 
int Partition(Type a[],int p,int r)
{
	int i = p,j = r + 1;
	Type x = a[p];

	while(true)
	{
		while(a[++i]x);
		if(i>=j)
		{
			break;
		}
		Swap(a[i],a[j]);
	}
	a[p] = a[j];
	a[j] = x;
	return j;
}

template
int RandomizedPartition(Type a[],int p,int r)
{
	int i = Random(p,r);
	Swap(a[i],a[p]);
	return Partition(a,p,r);
}

template 
void RandomizedQuickSort(Type a[],int p,int r)
{
	if(p

你可能感兴趣的:(算法,算法笔记——《算法设计与分析》)