【数据结构】排序(一)—— 希尔排序(思路演进版)

目录

一、常见的排序算法分类

二、常见排序算法的实现 

2.1插入排序

2.1.1基本思想

2.1.2直接插入排序

思路

step1.单趟控制

step2.总体控制 

代码实现

测试

特性总结

2.1.3 希尔排序( 缩小增量排序 )

基本思想

思路演进

🌈1.代码实现单组排序(以红色组为例)

🌈2.加入控制多组排序的代码

🌈3.对上面代码修改 ,一组一组排 改为 多组并排!!!

🌈4.最后考虑,如何控制gap?

最终代码实现

测试

特性总结

三、结语


一、常见的排序算法分类

二、常见排序算法的实现 

2.1插入排序

2.1.1基本思想

直接插入排序是一种简单的插入排序法,其基本思想是:

把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为 止,得到一个新的有序序列 。

 2.1.2直接插入排序

思路
step1.单趟控制

先考虑单趟排序,暂时不考虑区间到底是从哪到哪 ,先抽象为[0,end]

假设[0,end]是有序的区间 a[end+1] 插入到 [0,end]中

具体如何插入:

下标是end+1的元素依次跟[0,end]区间中的元素作比较:

end+1先跟end比 再跟 end-1比较......依次往下

如果a[end+1]<a[end] 以排升序为例子 ,那么a[end]就往后挪动 也就是往后覆盖

如果a[end+1]>a[end] ,那么就停止比较 ,a[end+1] 插入到 [0,end]中

❓思路落实到代码:

用临时变量tmp 先保存a[end+1],最终插入的位置也是a[end+1]

step2.总体控制 

接下来考虑如何控制[0,end]区间大小的变化:

执行过程描述:

初始时 区间元素个数肯定只有一个,

也就是end = 0 ,区间[0,0]有序,只有一个元素a[0],然后a[1]往里插入,

完成后,end = 1,区间[0,1]有序,有两个元素,a[2]往里插入...

直到整个数组元素都有序,排序完成。

❓思路落实到代码:

执行过程中,我们发现,end的值不断变化的,所以加入外层循环变量i控制即可!

代码实现
void InsertSort(int* a, int n)
{//外层循环 控制 多趟[0,end]for (int i = 0; i < n-1; i++){//单趟//[0,end] end+1 插入 [0,end]int end = i;int tmp = a[end + 1];while (end >= 0){//升序if (tmp < a[end]){//end 往后覆盖 end+1a[end + 1] = a[end];end--;}else{break;}}a[end + 1] = tmp;}
}
测试

特性总结

1. 元素集合越接近有序,直接插入排序算法的时间效率越高

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

3. 空间复杂度:O(1),它是一种稳定的排序算法

4. 稳定性:稳定

 2.1.3 希尔排序( 缩小增量排序 )

基本思想

希尔排序法又称缩小增量法。希尔排序法的基本思想是:

先选定一个整数gap,把待排序文件中所有记录分成多个组,所有距离为gap的记录分在同一组内,并对每一组内的记录进行排序。然后,再往后依次取 间隔为gap的记录,重复上述分组和排序的工作。当gap==1时,所有记录在统一组内排好序。

思路演进

总体思路:

1、预排序:分别对每个分组进行插入排序

2、直接插入排序 :保证最终结果是有序的

先选定一个整数 ,先假设 gap = 3.  图解

🌈1.代码实现单组排序(以红色组为例)

🌈2.加入控制多组排序的代码

总体有gap组 排完红色组 接着排 蓝色组、绿色组 则需要再加入一层循环控制

j==0 红色组 插入排序

j==1 蓝色组 插入排序

j==2 绿色组 插入排序

🌈3.对上面代码修改 ,一组一组排 改为 多组并排!!!

上面代码是 : 红色组排完 排绿色组  绿色排完 排蓝色组

下面代码是 : 红色组第一个位置排好,

                        i++ 排蓝色组第一个位置 ,

                       再 i++ 排绿色组第一个位置

                       以此类推......

 实现多组并排:

🌈4.最后考虑,如何控制gap?

gap越大:小的值更快调到前面,大的值更快调到后面

gap越小:调得越慢 但 越接近有序

gap==1 :就是直接插入排序

所以我们再加入一层循环 控制gap

最终代码实现
void ShellSort(int* a, int n)
{int gap = n;while (gap > 1){gap = gap / 2 ;for (int i = 0; i < n - gap; i ++){//单趟//[0,end] end+gap 插入 [0,end]int end = i;int tmp = a[end + gap];while (end >= 0){//升序if (tmp < a[end]){//end 往后覆盖a[end + gap] = a[end];end -= gap;}else{break;}}a[end + gap] = tmp;}}
}
测试

特性总结

1. 希尔排序是对直接插入排序的优化。

2. 当gap > 1时都是预排序,目的是让数组接近于有序

    当gap == 1时,数组已经是接近有序,再进行直接插入排序,目的是让数组有序

    这样整体而言,可以达到优化的效果。我们实现后可以进行性能测试的对比。

3. 希尔排序的时间复杂度不好计算,因为gap的取值方法很多,导致很难去计算,因此在好些树中给出的希尔排序的时间复杂度都不固定。平均时间复杂度O(N^1.3)

三、结语

插入排序就先讲到这里,后面滴选择、交换、归并排序,都会快快更新滴~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/10844.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

你能坚持二十年如一日地积极试错吗?

你能坚持二十年如一日地积极试错吗&#xff1f;先说一个大家都耳熟能详的人物&#xff1a;克里斯托弗哥伦布&#xff0c;他被称为新大陆的发现者&#xff0c;是具有极高历史地位的伟大航海家。 但是新大陆本来就不是所谓的“新”大陆&#xff0c;而是在4万年前从白令海峡迁徙过…

端午节线上活动方案怎么写?

一年一端午&#xff0c;一岁一安康。 如果您想组织端午活动&#xff0c;却不知道如何安排&#xff0c;可以看看何策网&#xff0c;有很多案例参考&#xff0c;仿造模板修改即可。 下面分享一个线上端午节活动策划方案&#xff0c;希望能帮到你&#xff01; 端午节作为祭祖祈…

Qt 实现TCP 协议的断开重连

在Qt中实现TCP断开重连&#xff0c;你可以使用QTcpSocket类&#xff0c;并结合QTimer来处理重连逻辑&#xff0c;在Qt中实现TCP断开后的自动重连功能&#xff0c;通常可以通过以下步骤进行&#xff1a; 1. 初始化QTcpSocket&#xff1a; 首先&#xff0c;需要创建一个QTcpSock…

Docker使用注意事项

docker import 和 docker load 有什么区别&#xff1f; 想要了解 docker load 与 docker import 命令的区别&#xff0c;还必须知道 docker save 与 docker export docker save&#xff1a;将一个镜像导出为文件&#xff0c;再使用docker load命令将文件导入为一个镜像&#…

mysql集群NDBcluster引擎在写入数据时报错 (1114, “The table ‘ads‘ is full“)

问题描述&#xff1a;mysql集群在写入数据时&#xff0c;出现上述报错 问题原因&#xff1a;表数据已满&#xff0c;一般是在集群的管理节点设置里面datamemory的值太小&#xff0c;当数据量超过该值时就会出现该问题 解决方案&#xff1a; 修改集群管理节点的config.ini里面…

ICode国际青少年编程竞赛- Python-4级训练场-嵌套for循环练习2

ICode国际青少年编程竞赛- Python-4级训练场-嵌套for循环练习2 1、 for i in range(3):Dev.turnRight()for j in range(3):Dev.step(-3)Dev.turnRight()Dev.step(4-2*i)2、 for i in range(6):for j in range(2):Dev.step(2 2 * i)if i > 3: Dev.step(i - 2)Dev.turnRi…

更相减损术求最大公约数

1.定义 更相减损术是出自《九章算术》的一种求最大公约数的算法&#xff0c;它原本是为约分而设计的&#xff0c;但它适用于任何需要求最大公约数的场合。 原文是&#xff1a; 可半者半之&#xff0c;不可半者&#xff0c;副置分母、子之数&#xff0c;以少减多&#xff0c;…

C++小程序:同一路由器下两台计算机间简单通信(2/2)——客户端

客户端的程序结构前半部分与服务器端基本相同&#xff0c;后半部分也相对简单。相关函数的解释可以参考前文服务器端的内容。有关客户端的内容除个别地方外&#xff0c;就不再做长篇大论的解释。强调一点&#xff0c;如果将此程序移到其它电脑上运行&#xff0c;编译需要releas…

Ciphey无法安装的解决办法

安装过程纯属自己实践&#xff0c;满满干货 困扰我几天的问题终于解决了 我看着教程在window上安装 python3.8/python3.9/python3.10无论如何都安装不上&#xff0c; 在win10虚拟机仍然安装不上 可能是我电脑环境问题 解决办法&#xff1a; 在kali中安装&#xff0c;但是…

18_文件系统的制作-Ramdisk

文件系统的制作(Ramdisk) 本文介绍如何制作文件系统。另外, 由于Busybox 集合了很多工具,编译起来也非常方便。在讲解制作文件系统的时候,也会介绍 busybox 的编译和安装过程;介绍制作文件系统时,会详细介绍 Ramdisk 、 YAFFS2、JFFS2 及其它文件系统的制作。 1. 根文件系…

列表、字典、集合推导式

文章目录 前言1.列表推导式&#xff08;List Comprehension&#xff09;:2 字典推导式&#xff08;Dictionary Comprehension&#xff09;3 集合推导式&#xff08;Set Comprehension) 前言 在Python中&#xff0c;列表、字典、集合推导式是一种便捷的语法&#xff0c;用于根据…

第13节 第二种shellcode编写实战(2)

在第二种shellcode编写实战(1)的基础上&#xff0c;新增加一个CAPI类&#xff0c;将所有用到的函数都在这个类中做动态调用的处理&#xff0c;这样使得整个shellcode功能结构更加清晰。 1. 新建类CAPI&#xff08;即api.h和api.cpp两个文件&#xff09;&#xff1a; api.h&…

#DELPHI BASS库Windows平台下,实时更换输出设备

DELPHI BASS库Windows平台下&#xff0c;实时更换输出设备 #DELPHI BASS库Windows平台下&#xff0c;实时更换输出设备 取自网络&#xff0c;分享&#xff0c;项目嵌入无损音乐播放后&#xff0c;画蛇添足的功能分享&#xff01; 直接贴核心代码&#xff0c;看不明白去看说…

flutter自定义日期选择器按日、按月、自定义开始、结束时间

导入包flutter_datetime_picker: 1.5.0 封装 import package:atui/jade/utils/JadeColors.dart; import package:flutter/cupertino.dart; import package:flutter/material.dart; import package:flutter_datetime_picker/flutter_datetime_picker.dart; import package:flut…

景源畅信电商:经营抖店需要电脑吗?

经营抖店是否需要电脑?这个问题看似简单&#xff0c;实则关乎着商家的运营效率和成本投入。在当前数字化、网络化的商业环境中&#xff0c;电脑已经成为了不可或缺的工具。那么&#xff0c;经营抖店究竟是否需要电脑呢?答案是肯定的。 一、高效处理订单 电脑能够高效地处理大…

Mysql FLOAT和DOUBLE类型区别

存储方式&#xff1a; FLOAT和DOUBLE是浮点数类型&#xff0c;它们以二进制格式存储数值&#xff0c;可以存储近似值。这意味着某些特定的小数值可能无法精确表示&#xff0c;可能会有微小的计算误差。DECIMAL是定点数类型&#xff0c;以字符串形式存储数值&#xff0c;可以存储…

从零学算法2105

2105. 给植物浇水 II Alice 和 Bob 打算给花园里的 n 株植物浇水。植物排成一行&#xff0c;从左到右进行标记&#xff0c;编号从 0 到 n - 1 。其中&#xff0c;第 i 株植物的位置是 x i 。 每一株植物都需要浇特定量的水。Alice 和 Bob 每人有一个水罐&#xff0c;最初是满的…

如何在湖师大官网找到考研真题

今天学弟问我怎么找真题&#xff0c;我必须告诉他怎么找湖师大的真题&#xff0c;身为考研学子&#xff0c;这是必须要知道滴&#xff0c;尤其是自命题&#xff0c;是吧&#xff0c;话不多说&#xff0c;言归正传&#xff0c;我们开始吧&#xff01; 1 打开湖师大官网 什么&a…

树莓派nmap扫描

debian系统安装nmap&#xff1a; sudo apt install nmap安装nmap完成后&#xff0c;输入 ip route 来查看当前Wi-Fi路由器的ip地址。 第一行的default via后显示的便是网关地址&#xff0c;也就是路由器地址。 获取到路由器ip地址后&#xff0c;在终端中输入&#xff1a; …

一站式HMI软件开发套件eStation,让开发更简单高效

4月份举办的北京国际车展上全球首发车117辆&#xff0c;新能源车型278个&#xff0c;越来越多的车厂通过差异化和改善UI/UE体验&#xff0c;来获取更多用户的青睐。为快速响应差异化竞争需求&#xff0c;智能座舱HMI市场遇到以下挑战&#xff1a; 如何兼容不同项目开发人员编程…