排序算法之快速排序算法
快速排序算法

快速排序算法和冒泡排序算法都属于交换排序算法,其中快速排序算法可以看做是冒泡排序算法的升级版。

快速排序算法的思想:在一列需要排序的数中,首先随机选一个基准数,一般选开始元素。这里我们定义两个变量i和j,我们给i,j取个好听名字,称为赶路人。i,j赶路人分别从最左边和最右边相向赶路。j从最右边的位置开始,若找到一个数比基准数小,就停止。然后i从最左边的位置开始,若找到一个数比基准数大,就停止。然后把i,j当前位置对应的值互换。然后i,j两点继续“赶路”,按照上面的模式,当i和j重复了,就停止赶路。此时在把i对应的值和开始设置的基准数互换,这就找到了开始时基准数的真正位置,此时保证了基准数右边的值不小于基准数,左边的数不大于基准数。其次,把基准位置两边的数,按照上面的规则进行下去,最后一直递归下去,最后就实现了快速排序。

void quicksort( int num[],int begin ,int end)
{
	int temp = num[begin];//随机的基准点
	int i = begin;
	int j = end;
	if (begin >= end)return;
	while(i!=j)
	{
		while(num[j] >= temp && i < j)j--;
		while(num[i] <= temp && i < j)i++;
		if(i < j)
		{
			int t = num[j];
			num[j] = num[i];
			num[i] = t; 

		}
	}
	num[begin] = num[i];
	num[i] = temp;

	quicksort( num,begin,i - 1);
	quicksort( num,i + 1,end);
}

int main()
{
	int a[] ={110,23,56,7,2,5,1,56,90,11,24,5,7,89,12,34,5,99};
	quicksort(a,0,17);
	for(int i = 0;i < 18;i++)  printf("%d ",a[i]); 
    getchar();
    return 0; 
}


阅读更多
文章标签: 排序算法
个人分类: 面试
想对作者说点什么? 我来说一句

典型排序法比较 C++实现编程

2009年10月17日 2.58MB 下载

没有更多推荐了,返回首页

不良信息举报

排序算法之快速排序算法

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭