算法系列5之交换排序

一.交换排序

1.冒泡排序

(1)冒泡排序:从头开始按照大小两两交换排序

(2)选择排序:先找到最大/小的,在和最后/前的位置交换(备份下标)...再依次找第二大/小的

(3)冒泡优化:在第一层循环中添加标志位,如果交换函数执行,标志位定为0;未执行,证明该数组有序,直接退出第一层循环

(4)冒泡优化2:交换的过程中,交换到某个值时,后面都不再进行交换,证明后面全部有序,下次直接从该值之前进行交换即可

例:假设从49之后全部有序,下次直接冒泡49之前的即可

2.快速排序

思想

x^2+y^2<(x+y)^2

意思是把一组数据不断的进行分割排序,理解上面的公式,时间复杂度不断的变小

双边排序法

1.备份第一个值和最后一个值充当挡板 ,在任意找一个值当做基点

2.先从右边开始,右边的值凡是大于基点值,就--right;之后在找左边,同理凡是小于的,left++

3.都找到后便交换这两个不符合上述条件的值,while循环直到 left=right 后该轮全部结束

4.最后把基点值和left/right的值交换,递归重复排序

变化的过程

核心:找基点

单边排序法

思想

1.备份startIndex对应的值,定义mark记录下标startIndex,索引i从startIndex+1位置开始

2.往后依次判断,如果小于备份值,该值和mark交换,mark++

3.走完之后,把mark标记的数据和基点(startIndex)标记数据交换,递归重复此操作

二.代码

1.冒泡代码

.h

.c

main.c

2.快排代码

.h

.c

相关推荐
OYpBNTQXi1 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
筱璦1 小时前
期货软件开发 - C# 调用 HQChart 指标计算 C++ 动态库
c++·microsoft·c#
yuannl102 小时前
数据结构----队列的实现
数据结构
蚂蚁数据AntData2 小时前
破解AI“机器味“困境:HeartBench评测实践详解
大数据·人工智能·算法·机器学习·语言模型·开源
ZC跨境爬虫2 小时前
Python异步IO详解:原理、应用场景与实战指南(高并发爬虫首选)
爬虫·python·算法·自动化
不想写代码的星星2 小时前
C++ 内存管理:分区、自定义分配器、常见问题与检测工具
c++
senijusene2 小时前
IMX6ULL 平台 I2C 总线:从硬件原理到裸机驱动
c语言·arm开发·驱动开发
Mr_Xuhhh2 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
kelleyv2 小时前
C语言过时了?C3和Zig谁能拯救它
c语言·zig·c3·系统级开发·语言革新
倦王2 小时前
力扣日刷47-补
python·算法·leetcode