四大常用排序算法

冒泡排序(相当于排身高):

1.概念:通过重复比较相邻元素并交换位置,使最大元素逐步 "浮" 到数组末端。

2.特点:

(1)时间复杂度:O (n²);

(2)空间复杂度:O (1);

(3)稳定性:稳定;

(4)适用于小规模数据或几乎有序的数据。

3.字符含义:n表示数组长度,n-1表示此次排序需要排几轮,n-i-1表示每轮排序需要比较几次(一比较就交换数据)

4.代码实现:

选择排序相当于打擂台,输的人一直打,直到所有人都上过场):

1.概念:每次从待排序部分找到最小元素,与待排序部分的第一个元素交换位置。(第一轮找到最小的放在第一位,第二轮找到剩余部分最小的放在第二位......)。

2.特点:

(1)时间复杂度:O (n²);

(2)空间复杂度:O (1);

(3)稳定性:不稳定;

(4)交换次数少(n-1次),适用于数据移动成本较高的场景。(一轮比完才交换数据)

3.代码实现:

快速排序(立标杆):

1.概念:采用分治法,选择一个基准元素,将数组分为两部分,左部分小于基准,右部分大于基准,然后递归排序两部分。

2.特点:

(1)时间复杂度:平均 O (nlogn),最坏 O (n²);

(2)空间复杂度:O (logn);

(3)稳定性:不稳定;

(4)实际应用中性能优秀,适用于大规模数据。

3.代码实现:

插入排序(相当于整理扑克牌):

1.概念:将未排序的元素逐个插入到已排序序列的适当位置

2.特点:

(1)时间复杂度:O (n²)(最坏和平均情况),最好情况为 O (n)(已排序数组)

(2)空间复杂度:O (1)(只需要一个临时变量)

(3)稳定性:稳定(相等元素的相对顺序不会改变)

(4)适用场景:

a.小规模数据排序;

B.部分有序的数据(接近有序时效率很高);

c.数据增量式插入场景(如实时数据排序).

3.代码实现:

相关推荐
仟濹11 分钟前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事14 分钟前
简单模板笔记
数据结构·笔记·算法
YuTaoShao29 分钟前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头35 分钟前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa1 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior1 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος19001 小时前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面
xhbaitxl1 小时前
算法学习day39-动态规划
学习·算法·动态规划
I_LPL1 小时前
day23 代码随想录算法训练营 回溯专题2
算法·hot100·回溯算法·求职面试
智者知已应修善业1 小时前
【洛谷P9975奶牛被病毒传染最少数量推导,导出多样例】2025-2-26
c语言·c++·经验分享·笔记·算法·推荐算法