首页 > 其他分享 >手撕排序2--选择排序(直接选择+堆排序

手撕排序2--选择排序(直接选择+堆排序

时间:2024-06-21 23:27:30浏览次数:27  
标签:arr end -- 堆排序 begin int child 排序

目录:

1.直接选择排序  的实现及分析

2.堆排序 的实现及分析


1.直接选择排序

1.1基本思想:

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

1.2

一次排序-->将最大值放在第一个,最小值放在最后一个

代码实现:

#include<stdio.h>
void Swap(int* a, int* b)
{
	int m = *a;
	*a = *b;
	*b = m;
}
void SelectSort(int* a, int n)
{
	int begin = 0, end = n - 1;
	while (begin < end)
	{
		int min_i = begin, max_i = begin;
		for (int i = begin; i <= end; i++)
		{
			if (a[i] < a[min_i])
			{
				min_i = i;
			}
			if (a[i] > a[max_i])
			{
				max_i = i;
			}
		}
		Swap(&a[begin], &a[min_i]);
		if (begin == max_i)
		{
			max_i = min_i;
		}
		Swap(&a[max_i], &a[end]);
		++begin;
		--end;
	}
}
int main()
{
	int arr[] = {23,45,99,0,1,14,689};
	int n = sizeof(arr) / sizeof(int);
	SelectSort(arr, n);
	printf("最小值为:%d\n", arr[0]);
	printf("最大值为:%d", arr[n - 1]);
	return 0;
}

测试结果: 

1.3直接选择排序的特性总结: 

1. 直接选择排序思考非常好理解,但是效率不是很好,实际中很少使用。

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

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

4. 稳定性:不稳定

2.堆排序 Heapsort

堆排序是利用堆 这种数据结构而设计的一种排序算法,它是选择排序的一种。它是通过堆来进行选择数据。需要注意的是排升序要建大堆,排降序建小堆。

2.1什么是堆呢?

堆的逻辑结构是:一棵完全二叉树

       物理结构是:一个数组

每个结点的值都大于或等于其左右孩子结点的值,称为大顶堆

每个结点的值都小于或等于其左右孩子结点的值,称为小顶堆

2.2向下调整算法

前提:该节点的左右子树都为 大/小堆

该算法就是将该节点与左右子树的节点进行比较,重新构建成一个大堆或者小堆。


例如:构建大堆 举例 

2.3 堆排序整体思路:(升序)-->大堆

1. 对待排序的数组,先构建成 堆

2. 从倒数第一个非叶子节点开始调整,把最大的换到最后,不把其看做是堆里的。前n-1个数向下调整,选出次大的数,再跟倒数第二个位置交换........

3. 如此反复执行,便能得到一个有序序列

堆排序的特性总结: 

 1. 堆排序使用堆来选数,效率就高了很多。

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

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

4. 稳定性:不稳定 

代码实现:

#include<stdio.h>
void Swap(int* a, int* b)
{
	int m = *a;
	*a = *b;
	*b = m;
}
void AdjustDown(int* a, int n, int root)
{
	int parent = root;
	int child = parent * 2 + 1;
	while (child < n)
	{
		if (child + 1 < n && a[child + 1] > a[child])
		{
			child += 1;
		}
		if (a[child] > a[parent])
		{
			Swap(&a[child], &a[parent]);
			parent = child;
			child = parent * 2 + 1;
		}
		else
		{
			break;
		}
	}
}
void HeapSort(int* a, int n)
{
	//建堆 O(N)
	for (int i = (n - 1 - 1) / 2; i >= 0; --i)
	{      
		AdjustDown(a, n, i);
	}
	int end = n - 1;
	while (end > 0)
	{
		Swap(&a[0], &a[end]);
		AdjustDown(a, end, 0);
		--end; 
	}          
}
int main()
{
	int arr[] = { 23,45,11,89,0,14,99 };
	int n = sizeof(arr) / sizeof(int);
	HeapSort(arr, n);
	for (int i = 0; i < n; i++)
	{
		printf("%d ", arr[i]);
	}
		return 0;
}

测试代码: 

谢谢观看,希望对你有所帮助

标签:arr,end,--,堆排序,begin,int,child,排序
From: https://blog.csdn.net/2302_81153999/article/details/139789369

相关文章

  • Rocky Linux捣鼓记录(一):如何安装使用中文输入法
    linux的常见输入法方案有fcitx、ibus,fcitx类型的输入法我没找到合适方案,ibus提供了一个智能拼音中文输入法比较顺手,安装简单。我使用的系统版本为RockyLinux9.4,已经自带ibus中文输入法,从设置——keyboard中选择输入源,新增——汉语(中国)选择——中文(智能拼音)即可若系统中没有,......
  • [TypeScript 学习笔记] 1. 日常类型
    TypeScript类型基础类型类型解释string用于文本字符串number用于数字(整数和浮点数)boolean布尔值,可以是true或falsenull表示缺少值的空对象指针undefined表示未定义的值void表示没有任何返回值的函数never表示永远不会返回的函数任意......
  • C# 13(.Net 9) 中的新特性 - 扩展类型
    C#13即.Net9按照计划会在2024年11月发布,目前一些新特性已经定型,今天让我们来预览一个比较大型比较重要的新特性:扩展类型Extensiontypes在5月份的微软Build大会中的What’snewinC#13会议上,两位大佬花了很长的篇幅来演示这个特性。这个特性一直是大家很关心的,在g......
  • ASCII 码表 unicode表 utf8表
     ASCII码表只包含0到127的字符表示,用单个字节即可表示。而对于超过127的字符,比如0x9A,无法用ASCII码表表示。对于超过ASCII码表的字符,可以使用其他字符编码表来表示,如Unicode编码表。Unicode是一种用于表示所有字符的标准编码系统,它包含了全球范围内的字符集,......
  • 双AdguardHome配置做DNS服务器
    双AdguardHome配置做DNS服务器概述看到网上dns泄露的文章,准备重新修改一下家里的网络配置后面准备使用mosDns作为53端口入口,使用两个adguardHome,一个插件的,专门用于国内的dns服务器,一个使用docker安装adguardHome,专门用于国外dns服务器MosDns配置使用docker安装adguardHome......
  • 学习Angr记录--angr_ctf 00~05
    首先,下载angr_ctf,打开dist文件夹,这里才是练习题,然后solution是答案00.find01.avoid前面两个是基础操作复习一下流程:1.项目路径2.进入状态3.模拟器模拟进入状态时的环境4.模拟器explore,find一个地址,avoid一些地址5.simulation.found[]数组存储成功的输入6.print(solutio......
  • 【Mac 从 0 到 1 保姆级配置教程 03】 - 安装配置美化 iterm2 一气呵成,Mac 下经久不衰
    1.前言如果你让我给别人推荐一款Mac下的终端,那我会毫不犹豫的推荐iterm2,因为它足够经典,足够好用。当然优秀的终端有很多,比如:alacritty、kitty等,大家感兴趣的可以尝试一下。我们今天主要讲解iterm2的安装、配置和美化。2.安装iterm2brewinstall--caskiterm......
  • 计算机网络:408考研|重要拓展内容|冷门考点|英文缩写词(完结撒花~)
    系列目录408计算机网络总纲领更新日志6.15物理层的接口特性,修改了部分排版问题6.17数据链路层的拥塞控制,补充部分额外英文缩写词6.21考纲中明确提到的物理层的信源与信宿;数据链路层的ALOHA协议和令牌传递协议;以及运输层的UDP校验目录系列目录更新日志拓展......
  • 01、Shell 编程规范与变量
    目录1.1Shell脚本概述1.1.1Shell的作用        1.1.2编写第一个Shell脚本        1.1.3重定向与管道操作1.重定向操作2.管道操作1.2Shell变量的作用、类型1.2.1自定义变量1.定义新的变量2.查看和引用变量的值3.变量赋值的特殊操作4.设置变......
  • FreeBSD通过CBSD管理低资源容器jail 网络NAT配置
    jail容器里的系统有时候并不需要公开的地址,所以给它们配置内网地址即可。但是这些系统一般都有上网的需求,这时候可以使用nat进行解决。CBSD可以配置NAT规则,只需要命令cbsdnatcfg,配置好后cbsdnaton启动即可:%cbsdnatcfgConfigureNATforRFC1918Network?[yes(1)orn......