快速排序之hoare法

                                                   hoare法

首先我们来看它的基本思路:

    第一步:选择待排序数组中的三个值,分别是首尾还有中值,start,end 和mid
    第二步:对三个数进行排序,从小到大,
    第三步:保护基准值,swap(src + mid, src + end - 1);也就是基准值和倒数第二个元素交换
    第四步:a = start + 1, b = end - 2,b向前找比基准值小的,a向后找比基准值大的,找到之后 交换所指向的值,然后将基准值和a指向的值交换 (因为是从小到大排序a找的大的,应该在数组后面所以基准值和它换),产生左边的都比基准值小,右边的都比基准值大,然后a作为二叉树的根返回,重复上面四步操作,直到类似形状的二叉树被遍历完为止

代码实现:

int hoareway(int* src, int start,int end)
{
	int a = start + 1, b = end - 2;
	int mid = (start + end) / 2;
	if (src[start] > src[mid])
	{
		swap(src + start, src + mid);
	}
	if (src[mid] > src[end])
	{
		swap(src + mid, src + end);
	}
	if (src[start] > src[mid])
	{
		swap(src + start, src + mid);
		/*上面是三数排序部分*/
	}
	if (end-mid<=2)
	{
		return mid;
		/*如果小于4个数直接返回输出*/
	}
	/*保护基准值*/
	swap(src + mid, src + end - 1);
	while (a <= b)
	{
 		while (a < end-1 && src[a] <= src[end-1])
		{

			a++;
		}
		while (b > 0 && src[b] >= src[end-1])
		{
			b--;

		}
		if (a == b && (a == 1 || a == end-1))
		{
			break;
			/*一种是找到同一个值,一种是找到了已经三数排好的地方,此时就不用排*/
		}
		if (a < b)
		{
			swap(src + a, src + b);
			/* 交换*/
		}
		
	}
	swap(src + a, src + end - 1);
	return a;
}

void dealquicksort(int *src, int start, int end)
{
	int mid;
	if (start<end)
	{
		mid = hoareway( src,  start,   end);
		dealquicksort( src, start, mid-1);
		dealquicksort(src, mid + 1, end);
	}
}
void quicksort(int *src, int n)
{
	//快速排序
	dealquicksort(src, 0, n-1);
}

如果递归思想有不明白请看https://blog.csdn.net/weixin_43447989/article/details/100054493

EOF

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 快速排序Hoare是一种常用的快速排序实现方。它是由Tony Hoare在1960年提出的。Hoare的基本思想是选择一个基准值,将待排序序列分成两部分,一部分是小于基准值的元素,另一部分是大于基准值的元素。然后对这两部分分别进行递归排序,最终将整个序列排序完成。具体实现过程如下: 1. 选择一个基准值,可以是序列中的任意一个元素。 2. 定义两个指针,一个指向序列的起始位置,一个指向序列的末尾位置。 3. 移动左指针,直到找到一个大于等于基准值的元素。 4. 移动右指针,直到找到一个小于等于基准值的元素。 5. 如果左指针小于等于右指针,则交换左右指针所指向的元素。 6. 继续移动左右指针,直到左指针大于右指针。 7. 将基准值与右指针所指向的元素交换。 8. 分别对基准值左边和右边的子序列进行递归排序。 通过以上步骤,每一次递归都会将基准值放置在正确的位置上,最终完成整个序列的排序。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* [【八大排序③】快速排序(动图演绎Hoare、挖坑、前后指针)](https://blog.csdn.net/Living_Amethyst/article/details/125513838)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [快速排序常见3种方(hoare、挖坑、前后指针)以及改进。](https://blog.csdn.net/tjh1998/article/details/122159488)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值