# 七大基于比较的排序算法汇总
基于比较的排序算法汇总,这些排序算法之所以能够将元素进行排序 ,依赖于元素和元素之间的比较,以下的数组元素类型都需要实现Comparable接口。
#### 介绍
##### [选择排序法](./src/com/wkq/selectionsort/SelectionSort.java)
算法思想:每次处理还没处理元素里最小的元素
##### [插入排序法](./src/com/wkq/insertionsort/InsertionSort.java)
##### 归并排序法: O(nlogn)求解数组中逆序对个数
* 自顶向下的归并排序法
* 自底向上的归并排序法
##### 快速排序法:随机算法 O(n)求解selectK,topK 问题
* 单路快速排序法: 如果数据中包含大量重复元素的话,也会退化成一个O(n^2)级别的算法,快速排序法不应该采用单路快速排序法
* 双路快速排序法:
* 三路快速排序法:
##### 堆排序法 : 堆;优先队列,求解selectK,topK 问题
* 把所有的数据都扔进一个堆中,再依次从堆中取出这些数据,取出来的过程其实就已经排好序了,但是这样做空间是O(n)的
* 可以通过Heapify在原地进行堆排序,这样空间不仅变成了O(1)级别,在性能上也变优了一些
##### [冒泡排序法](./src/com/wkq/bubblesort/BubbleSort.java)
O(n^2)的排序算法
基本思想:每次比较相邻的两个元素
第i轮开始,arr[n-i,n)已经排好序
第i轮:通过冒泡在arr[n-i-1]位置上放上合适的元素
第i轮结束:arr[n-i-1,n)已排好序
##### [希尔排序法](./src/com/wkq/shellsort/ShellSort.java): 分组的思想
基本思想:让数组越来越有序,不能只处理相邻的逆序对
对元素间距为n/2的所有数组做插入排序
对元素间距为n/4的所有数组做插入排序
对元素间距为n/8的所有数组做插入排序
...
对元素间距为1的所有数组做插入排序
![基于比较的排序算法总结](https://images.gitee.com/uploads/images/2022/0308/215017_f51296ae_8411299.png "屏幕截图.png")
基于比较的排序算法汇总 选择排序法 插入排序法 归并排序法 快速排序法 堆排序法 冒泡排序法 希尔排序法
2 浏览量
2024-01-15
10:37:17
上传
评论
收藏 18KB ZIP 举报
十小大
- 粉丝: 9213
- 资源: 2552
最新资源
- 论文(最终)_20240430235101.pdf
- 基于python编写的Keras深度学习框架开发,利用卷积神经网络CNN,快速识别图片并进行分类
- 最全空间计量实证方法(空间杜宾模型和检验以及结果解释文档).txt
- 5uonly.apk
- 蓝桥杯Python组的历年真题
- 2023-04-06-项目笔记 - 第一百十九阶段 - 4.4.2.117全局变量的作用域-117 -2024.04.30
- 2023-04-06-项目笔记 - 第一百十九阶段 - 4.4.2.117全局变量的作用域-117 -2024.04.30
- 前端开发技术实验报告:内含4四实验&实验报告
- Highlight Plus v20.0.1
- 林周瑜-论文.docx
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈