各种排序的总结

希尔排序

⭐希尔排序,下标从1开始,0用于插入排序做哨兵

⭐希尔排序不稳定!


冒泡排序

第二趟,前边经过一系列对比后,走到下边这一步:

同理,第三趟也是

⭐冒泡排序每次交换都需要移动元素3次

⭐冒泡排序,每一趟都会使一个最大/最小元素在它的最终位置。


快速排序

⭐基准元素在最终位置,基准元素左边的都比它小,右边的都比它大,

⭐:下标从0开始

排序过程:

第一趟:

左边:

右边

快排代码:

cpp 复制代码
using namespace std;
#include<iostream>
#include<math.h>
const int N = 100010;
int n;

int a[N];
void quick_sort(int a[], int left, int right)
{
	if (left >= right)
	{
		return;
	}
	int x = a[left + right>>1], i = left-1, j = right+1;
	//相当于除以2但比除以2运算时间短

	while (i < j)
	{
		do i++; while (a[i] < x);
		do j--; while (a[j] > x);
		if (i < j)//交换
		{
			swap(a[i], a[j]);
		}
	}
	quick_sort(a, left, j);
	quick_sort(a, j + 1, right);

}
int main()
{
	cin >> n;
	for (int i = 0; i < n; i++)
	{
		cin >> a[i];
	}
	quick_sort(a, 0, n - 1);
	for (int i = 0; i < n; i++)
	{
		cout << a[i] << " ";

	}
	return 0;
}

简单选择排序

选择排序:每⼀趟在待排序元素中选取关键字最⼩(或最⼤)的元素加⼊有序⼦序列


堆排序

堆的插入和删除

删除元素:用最后一个元素代替


归并排序


基数排序

总结:

相关推荐
会编程的土豆43 分钟前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展
RH2312114 小时前
2026.4.29数据结构 直接插入排序&&希尔排序
数据结构·算法·排序算法
khalil10207 小时前
代码随想录算法训练营Day-41动态规划08 | 121. 买卖股票的最佳时机、122.买卖股票的最佳时机II、123.买卖股票的最佳时机III
数据结构·c++·算法·leetcode·动态规划
无限进步_8 小时前
【C++】AVL树完全解析:从平衡因子到四种旋转
c语言·开发语言·数据结构·c++·后端·算法·github
浅念-8 小时前
LeetCode最短路必看:BFS算法原理+经典题解
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
流年如夢9 小时前
顺序表的应用 --> 简单通讯录的实现
c语言·数据结构
如君愿9 小时前
考研复习 Day 31 | 习题--计算机网络 第五章(运输层 中)、数据结构 图 (中)
数据结构·计算机网络·课后习题
代码地平线9 小时前
【数据结构】二叉树详解:全代码逐行解析+6道LeetCode高频OJ题图解
数据结构·算法·leetcode
流年如夢10 小时前
顺序表(LeetCode)
c语言·数据结构·leetcode·职场和发展
say_fall10 小时前
校招必看:八大排序算法原理、复杂度与高频面试题
数据结构·c++·算法·排序算法