排序算法分类及其稳定性

排序算法可分为五类八种

类别

一、插入排序

1、直接插入排序 稳定

先对数组前两个元素进行比较和交换接着后面的元素依次作和前面的元素作比较和交换(插入)

2、希尔排序(shell排序) 不稳定

通过引入增量序列Ri 每次进行等距离Ri若干个元素的排序后再次进行R(i-1)<Ri的等距离元素排序 直至R(i-n)=1最后一次排序即可完成希尔排序

二、选择排序

1、直接选择排序 不稳定

先选出排序码最小的元素然后移入排序数组接着在剩下的元素中选出排序码最小的元素依次进行可得到一个有序序列

2、堆排序 不稳定

分为大根堆和小根堆,先建堆再移出堆顶元素再建堆的一个过程

三、交换排序

1、冒泡排序 稳定

先通过数组底部两个相邻元素(Xi和X(i-1))的比较和交换接着比较(X(i-2)和X(i-1))依次进行i的自减比较直到得到最小或最大元素 将其移出比较数组移入排序数组即可

2、快速排序(分治法) 不稳定

相当于二分查找的形式,将问题采用分治法的方式去解决,首先将数组首位元素确定为基准元素与末位元素比较,如果是顺序排序 则基准元素大于末位元素的话

基准元素和末位元素交换元素,且首指针+1尾指针不变 若基准元素小于末位元素的话则元素不交换首指针不变尾指针+1直到基准元素将原数组分隔为1个或多个数组然后再在剩余的数组里面采用递归的形式实现快速排序

四、归并排序 稳定

将问题分解区域化最终再合并处理

五、基数排序 稳定

采用个位排序、十位排序、百位排序等等依次的排序方式最终得出一个有序序列

排序时放入的数据结构相当于一个哈希表 索引为0-9

相关推荐
寒秋花开曾相惜3 小时前
(学习笔记)第四章 处理器体系结构
linux·网络·数据结构·笔记·学习
故事和你913 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__3 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__4 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
_日拱一卒5 小时前
LeetCode:2两数相加
算法·leetcode·职场和发展
py有趣5 小时前
力扣热门100题之零钱兑换
算法·leetcode
董董灿是个攻城狮5 小时前
Opus 4.7 来了,我并不建议你升级
算法
自我意识的多元宇宙5 小时前
二叉树遍历方式代码解读(2迭代)
数据结构