【九月打卡】第16天【养成记】嵌入式挑战第16天 学习shell排序
2022/9/22 3:17:15
本文主要是介绍【九月打卡】第16天【养成记】嵌入式挑战第16天 学习shell排序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
课程名称:
物联网/嵌入式工程师
课程章节(阶段二第七周 shell排序 1-6):
shell排序课程链接
老师:
大白老师
课程内容:
学习常用排序中的shell排序
学习笔记:
以下为排序过程:
- 希尔排序也是插入排序的一种。他是对直接插入排序的一种版本的改进。它的核心思维是先将整个待排元素序列分割成若干个子序列(一般元素的个数/2获得),然后对每个组分别进行直接插入排序。随着序列的逐渐减小,所包含的记录就越来越多,当序列为1的时候,整个数据合成一组。 则完成排序。
- 优缺点: 适合中小规模数据排序,不适合大型数据排序。
主要代码实现
void shell_sort(int *p,int plen) { int i = 0,j = 0,k = 0,temp = 0; for(k = plen / 2;k >= 1;k = k / 2) //分成的组数 { for(i = k;i < plen;i++ )//插入排序的次数 { temp = p[i]; for(j = i - k;j >=0 && p[j] > temp ;j = j - k)//找到每组中的元素,进行排列。 { //每组元素相隔k个 p[j + k] = p[j]; } p[j + k] = temp; } } }
打卡:
课程评价
本节主要讲解图的shell排序,过程有点绕人,但是跟着老师敲代码,基本上了解了,后面我还需要再复习一下😭。
这篇关于【九月打卡】第16天【养成记】嵌入式挑战第16天 学习shell排序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-19永别了,微服务架构!
- 2024-05-15鸿蒙生态设备数量超8亿台
- 2024-05-13TiDB + ES:转转业财系统亿级数据存储优化实践
- 2024-05-09“2024鸿蒙零基础快速实战-仿抖音App开发(ArkTS版)”实战课程已上线
- 2024-05-09聊聊如何通过arthas-tunnel-server来远程管理所有需要arthas监控的应用
- 2024-05-09log4j2这么配就对了
- 2024-05-09nginx修改Content-Type
- 2024-05-09Redis多数据源,看这篇就够了
- 2024-05-09Google Chrome驱动程序 124.0.6367.62(正式版本)去哪下载?
- 2024-05-09有没有大佬知道这种数据应该怎么抓取呀?