c语言 快速排序

c语言 快速排序 算法及实现
我们现在对6 1 2 7 9 3 4 5 10 8 进行快速排序
选左边第一个数作为基准数字
基本思想是对于除了基准数字的其他九个数字,大于基准数字的放在基准数字的右边,小于基准数字的放在基准数字的左边

具体实现过程
1. 以6位基准数字,从又往左看,若大于基准数字,则比较下一个数字
          例如8大于6,那么比较10 和 6, 10 大于 6 ,那么比较5 和 6, 5 小于6,此时停止右边的比较
2. 继续从左往右看, 若小于基准数字, 则比较下一个数字
          例如1 小于 6,比较 2 和6 , 2 小于 6, 比较7 和6, 7 大于 6,此时停止左边的比较
3. 交换右边停止位置的数和左边停止位置的数,这里是交换5 和 7;
          得到6 1 2 5 9 3 4 7 10 8
4. 继续比较7 左边的数据和基准数据的大小,直到满足1中的条件,停止。然后比较5 右边的数据和基准数据, 直到满足2的条件,停止。进行3的操作

5. 直到左边和右边相遇,将相遇处的数字和基准数字交换,第一轮排列结束
           这里的结果是  3 1 2 5 4 69 7 10 8

然后再分别对于相遇点左右两边的数据重复1-5的操作,直到排列结束(结束条件见代码)

#include <iostream>

using namespace std;

//快排函数
void quicksort(int * a ,  int left, int right); 

int main(void)
{
	int n;
	cin >>n;
	int a[101] = {0};

	for(int i=0; i<n; i++)
	{//输入数据
		cin >> a[i];
	}

	int left = 0;
	int right = n-1;
	//递归排序
	quicksort(a, left, right);

	for(int j=0; j<n; j++)
	{//输出结果
		cout << a[j] <<" ";
	}
	cout << endl;

	return 0;
}

void quicksort(int * a ,  int left, int right)
{
	int temp = a[left]; //基准数据//将左边第一个作为基准数据
	int i = left;
	int j = right;

	if(left > right)//结束条件
		return ;
	while(i != j)
	{//一直进行直到ij相遇
		while(a[j] >= temp && i < j)
		{//从最右边开始比较//必须的//如果大于基准数据,那么j--,否则,开始左边的比较
			j--;
		}
		while(a[i] <= temp && i < j)
		{//如果小于基准数据,i++, 否则交换a[i], a[j]
			i++;
		}

		if(i < j)
		{//交换
			int t = 0;
			t = a[i];
			a[i] = a[j];
			a[j] = t;
		}
		
	}

	//当i和j相遇时候,将基准数据和相遇点的数据交换
	a[left] = a[i];
	a[i] = temp;

	//递归排列相遇点左边和右边的数据
	quicksort(a, left, i-1);
	quicksort(a, i+1, right);
}

样例数据
10
6 1 2 7 9 3 4 5 10 8
输出截图




  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tailor_long

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值