关闭

排序算法之快速排序算法

标签: 排序算法
269人阅读 评论(0) 收藏 举报
分类:
快速排序算法

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

快速排序算法的思想:在一列需要排序的数中,首先随机选一个基准数,一般选开始元素。这里我们定义两个变量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; 
}


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:85093次
    • 积分:1955
    • 等级:
    • 排名:千里之外
    • 原创:112篇
    • 转载:6篇
    • 译文:0篇
    • 评论:3条