【C语言】排序算法——希尔排序以及插入排序 ——详解!!!

【C语言】排序算法——希尔排序以及插入排序 ——详解!!!

【C语言】排序算法——希尔排序以及插入排序详解

前言

在学习循环的时候,我们学习到了冒泡排序这个算法
那么,除了冒泡排序,还有什么排序算法呢?
今天给大家带来的是插入排序以及希尔排序

一 、插入排序

1. 视频演示

首先给大家看一段视频,让大家先看看插入排序是怎么运行的

插入排序演示

2. 算法思想

我们可以从视频里看见,插入排序就像是我们打扑克牌一样,一张一张插入到了有序队列
每次都有一个数据 x(标红的)要跟前面的数据一一比大小
若 x 比前一个数据小,则 x 就再向前比较
若 x 比前一个数据大,则 x 就插入到这个数据的后面

3. 实现思路

由视频可知,数据 x(标红的)前面的序列都是有序的,故每一次只需要将 x 插入其中即可
  • 第一步
我们给定下标范围【0,end】区间是有序的,tmp为要插入的数据的值,故tmp为下标为end + 1所对应的值
  • 第二步
将下标为end所对应的值与tmp比较
tmp比前一个数据小,则tmp就再向前一个数比较
tmp比前一个数据大,则tmp就插入到这个数据的后面
  • 第三步
循环遍历整个数组,直到数组全部插入进去

4. 代码演示

// 插入排序voidInsertSort(int* a,int n){for(int i =0; i < n -1; i++){int end = i;int tmp = a[end +1];while(end >=0){if(tmp < a[end]){ a[end +1]= a[end]; end--;}else{break;}} a[end +1]= tmp;}}

二 、希尔排序

1. 视频演示

首先给大家看一段视频,让大家先看看希尔排序是怎么运行的

希尔排序视频演示

2. 算法思想

当你看完视频,你也许就会发现希尔排序和插入排序很相似
只不过,希尔排序相当于间隔插入排序 n 次
而每一次都越来越接近有序数组,直到最后一次排成有序

3. 实现思路

那该怎么实现呢?

(1)分组

  • 第一步:分组
由视频可知,每次排序并不是一个一个排,而是每间隔几个数据成一组来排序
一组一组排,这组排完就到下一组,直到全部排完
这里先假设分成3组数据进行排序,也就是每隔2个数据成一组

如图:

在这里插入图片描述

(2)预排序

  • 第二步:预排序
分成了几组后,每一组就开始插入排序,称为预排序
插入排序前面讲了,就不赘述了

代码演示:
( gap 就是被分成了几组)

int gap = n;while(gap >1){ gap =3;for(int i =0; i < n - gap; i++){int end = i;int tmp = a[end + gap];while(end >=0){if(tmp < a[end]){ a[end + gap]= a[end]; end -= gap;}else{break;}} a[end + gap]= tmp;}}
预排序是干什么呢?
预排序的主要功能就是让一个数组接近有序,为了给后面的插入排序节省大量的时间

(3)最终排序

  • 第三步:最终排序
现在,在排序完三组数据后,我们的数组已经很接近有序
所以现在只需要用插入排序排最后一次收尾就行了

这里就不进行代码演示了,就是一个普通的插入排序

(4)gap的取值

  • 第四步:gap的取值
、前面我们的代码中 gap 的取值定为了 3,但是这不可能对于每个数组都适应
那么该如何给 gap 来取值呢?
根据科学的实验,发现当gapn / 3时,排序最快
所以,在排序的过程中,gap 的值是不断发生变化的
、到这里,可能已经有人发现了,刚刚写的预排序和前面写的插入排序几乎一摸一样
只是将 1 变成了 gap
>其实,当gap1时,就是普通的插入排序

那么我们能不能设计一个循环,既能在排序的过程中满足gap的动态变化,又能使gap的最后一次取值为 1 呢?

所以我们可以有一些改进,在函数外面再套一层循环:
int gap = n;
while (gap > 1)
{
gap = gap / 3 + 1;
…………
…………//这里省去代码
}

这样,gap能够很好的动态变化,且最后一次循环的gap值为1,恰好能完成一次普通的插入排序

4. 代码演示

代码演示:

// 希尔排序voidShellSort(int* a,int n){int gap = n;while(gap >1){ gap = gap /3+1;for(int i =0; i < n - gap; i++){int end = i;int tmp = a[end + gap];while(end >=0){if(tmp < a[end]){ a[end + gap]= a[end]; end -= gap;}else{break;}} a[end + gap]= tmp;}}}

结语

OK,本期的排序算法详解到这里就结束了

若内容对大家有所帮助,可以收藏慢慢看,感谢大家支持

本文有若有不足之处,希望各位兄弟们能给出宝贵的意见。谢谢大家!!!

新人,本期制作不易希望各位兄弟们能动动小手,三连走一走!!!

支持一下(三连必回QwQ)

Read more

【MySQL数据库基础】(三)MySQL 库的核心操作全解析:创建、修改、备份一条龙搞定

【MySQL数据库基础】(三)MySQL 库的核心操作全解析:创建、修改、备份一条龙搞定

前言         在 MySQL 的学习和实战中,数据库(库)的操作是最基础也是最核心的环节,无论是项目开发、数据管理还是运维维护,都绕不开库的创建、配置、修改、备份等一系列操作。很多刚接触 MySQL 的小伙伴容易在字符集、校验规则、备份恢复这些细节上踩坑,今天这篇文章就结合实战案例,把 MySQL 库的全套操作讲透,从基础语法到高级技巧,从避坑指南到实战演示,让你一文掌握 MySQL 库操作的精髓! 一、创建数据库:基础语法与个性化配置         创建数据库是操作 MySQL 的第一步,看似简单的一句命令,背后却藏着字符集、校验规则的关键配置,选对配置能让后续的开发和数据管理少走很多弯路。 1. 核心创建语法         MySQL 中创建数据库的官方语法如下,其中大写部分为关键字,中括号[]内的为可选项,也是实际开发中需要重点关注的部分: CREATE DATABASE [IF NOT EXISTS]

By Ne0inhk
Tomcat+cpolar 让 Java Web 应用轻松触达公网实操案例

Tomcat+cpolar 让 Java Web 应用轻松触达公网实操案例

Tomcat 作为轻量级 Java 应用服务器,核心功能是对 Java Servlet 和 JSP 提供完善支持,能稳定托管各类 Java Web 应用,它的适用人群覆盖了从入门级 Java 开发者到中小企业的技术人员,无论是个人开发调试小项目,还是企业部署中小型 Web 应用,都能适配。其优点十分突出,部署流程简单易懂,新手也能快速上手,同时占用系统资源少、启动速度快,兼容性强,绝大多数 Java 项目都能在其上正常运行。 使用 Tomcat 的过程中,有不少实用的心得值得分享:日常使用时要注意定期检查 Tomcat 的运行日志,及时发现端口占用、应用部署失败等问题;另外,默认的配置文件不要随意修改,若需调整端口、线程数等参数,建议先备份原文件,避免配置错误导致服务无法启动;还有,开发环境和生产环境的配置要区分开,生产环境需关闭不必要的调试功能,提升运行稳定性。

By Ne0inhk
网络爬虫【爬虫库request】

网络爬虫【爬虫库request】

我叫不三不四,很高兴见到大家,欢迎一起学习交流和进步 今天来讲一讲爬虫 Requests是Python的一个很实用的HTTP客户端库,完全满足如今网络爬虫的需求。与Urllib对比,Requests不仅具备Urllib的全部功能;在开发使用上,语法简单易懂,完全符合Python优雅、简洁的特性;在兼容性上,完全兼容Python 2和Python 3,具有较强的适用性。 请求方式 HTTP的请求方式分为GET和POST GET请求 url语法如下: # 不带参数 url_without_params = "https://www.baidu.com/" # 带参数 wd url_with_params = "https://www.baidu.com/s?参数名=参数值" 注:如果一个URL有多个参数,参数之间用“&”连接,

By Ne0inhk

懒人必备:三步搞定阿里通义Z-Image-Turbo WebUI部署

懒人必备:三步搞定阿里通义Z-Image-Turbo WebUI部署 作为一名自媒体创作者,我经常需要为文章配图,但传统的设计工具耗时耗力。最近尝试了阿里通义Z-Image-Turbo这款AI图像生成工具,发现它不仅能快速生成高质量配图,还支持商用授权。最关键的是,通过预置镜像部署,整个过程只需三步,完全不需要折腾复杂的模型环境。下面分享我的实测经验。 为什么选择阿里通义Z-Image-Turbo? * 商用友好:生成的图片可直接用于商业用途,无需担心版权问题 * 中文优化:对中文提示词的理解优于多数开源模型 * 速度快:512x512分辨率图片生成仅需2-3秒 * 零配置:预装所有依赖项,包括CUDA、PyTorch等深度学习框架 这类任务通常需要GPU环境,目前ZEEKLOG算力平台提供了包含该镜像的预置环境,可快速部署验证。 第一步:获取GPU环境并拉取镜像 1. 登录ZEEKLOG算力平台,选择"镜像市场" 2. 搜索"阿里通义Z-Image-Turbo"镜像 3. 点击"立即部署",选择至少8GB显存的GPU实例 部署完成后,

By Ne0inhk