12 选择排序和堆排序

选择排序

基本思想

每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完

直接选择排序

  • 在元素集合array[i]--array[n-1]中选择关键码最大(小)的数据元素
  • 若它不是这组元素的最后一个(第一个)元素,则将它与这组元素中的最后一个(第一个)元素交换
  • 在剩余的arrary[i]--array[n-2] (array[i+1]--array[n-1])集合中,重复以上步骤,直到集合剩余一个元素

    单纯找一个最大的或最小的有点慢,一次可以同时找出最大的和最小的,最小的下标从0开始,最大的下标从最后一个数开始,不断向内移动

需要注意最大的数可能刚好在最小的数要换过去的位置,这时,数值已经交换,已经不是原来的数,需要更新最大值的下标

c 复制代码
void SelectSort(int ary[], int len)
{
//最大数和最小数的下标
	int start = 0;
	int end = len - 1;

	while (start < end)
	{
	//记录最大数和最小数下标
		int mini = start;
		int maxi = end;
		for (int i = start; i <= end; i++)
		{
			if (ary[i] < ary[mini])
			{
				mini = i;
			}

			if (ary[i] > ary[maxi])
			{
				mini = i;
			}
		}

		Swap(&ary[start], &ary[mini]);
		//最大数在最小值交换过去的位置,更新下标
		if (start == maxi)
		{
			maxi = mini;
		}
		Swap(&ary[end], &ary[maxi]);
		start++;
		end--;

	}
	
}

堆排序

基本思想

利用堆设计的排序算法,是选择排序的一种。前提是数组必须已经是堆,所以用原数据建堆,不断替换缩小堆修改数组里元素的位置。排升序建大堆,排降序建小堆

过程

先用向下调整建堆,然后堆顶和数组结尾交换,重新调整堆,直到调整完

c 复制代码
```c
//堆排
void AdjustDown(int ary[], int len,int parent)
{
	//假设左孩子是最小的
	int child = parent * 2 + 1;

	while (child < len)
	{
		//如果右孩子大,更换
		if (child + 1 < len && ary[child + 1] > ary[child])
		{
			child = child + 1;
		}
		//比孩子小则交换,找出最大的
		if (ary[parent] < ary[child])
		{
			Swap(&ary[parent], &ary[child]);
			parent = child;
			child = parent * 2 + 1;
		}
		else
		{
			break;
		}
	}
	
}

void HeapSort(int ary[], int len)
{
	//向下调整建堆,i从最后一非叶子结点开始,调整到根
	for (int i = (len - 2) / 2; i >= 0; i--)
	{
		AdjustDown(ary, len, i);
	}

	//不断替换修改原数组
	int end = len - 1;
	while (end > 0)
	{
		//交换之后减少数组大小,调整堆
		Swap(&ary[0], &ary[end]);
		AdjustDown(ary, end, 0);
		end--;
	}
}

特性

1.效率高很多

2.时间复杂度:O(N*logN)

3.空间复杂度: O(1)

4.稳定性: 不稳定

相关推荐
zhurui_xiaozhuzaizai12 分钟前
模型训练-关于token【低概率token, 高熵token】
人工智能·算法·自然语言处理
ThreeYear_s18 分钟前
基于FPGA的PID算法学习———实现PID比例控制算法
学习·算法·fpga开发
CodeWithMe1 小时前
【C/C++】不同防止头文件重复包含的措施
c语言·开发语言·c++
子豪-中国机器人1 小时前
C++ 信息学奥赛总复习题答案解析
开发语言·c++·算法
弥彦_1 小时前
牛客round95D
c++·算法
whoarethenext2 小时前
使用 C/C++的OpenCV 实现模板匹配:从基础到优化
c语言·c++·opencv
强盛小灵通专卖员2 小时前
基于深度学习RT-DETR算法的盲人障碍物目标检测:提升盲人出行安全的智能化突破
深度学习·算法·目标检测·计算机视觉·rt-detr·小论文·计算机期刊
合方圆~小文3 小时前
架空线路图像视频监测装置
c语言·c++·人工智能·嵌入式硬件·硬件工程·模拟退火算法
我不是小upper3 小时前
统计学核心概念与现实应用精解(偏机器学习)
算法·机器学习·统计学
Renlijuande3 小时前
百度之星2021——BD202104 萌新
算法