-
Notifications
You must be signed in to change notification settings - Fork 20
Sort
kcp edited this page Jul 13, 2020
·
2 revisions
目录 start
目录 end|2020-04-27 23:42|
排序算法 | 平均时间复杂度 | 最好情况 | 最坏情况 | 空间复杂度 | 排序方式 | 稳定性 |
---|---|---|---|---|---|---|
冒泡 | n^2 | n | n^2 | 1 | In | 稳定 |
插入 | n^2 | n | n^2 | 1 | In | 稳定 |
选择 | n^2 | n^2 | n^2 | 1 | In | \ |
希尔 | n log n | n log n | n log n | 1 | In | \ |
归并 | n log n | n log n | n log n | n | Out | 稳定 |
快速 | n log n | n log n | n^2 | log n | In | \ |
堆 | n log n | n log n | n log n | 1 | In | \ |
计数 | n + k | n + k | n + k | k | Out | 稳定 |
桶 | n + k | n + k | n^2 | n + k | Out | 稳定 |
基数 | n * k | n * k | n * k | n + k | Out | 稳定 |
- n:数据规模
- k:"桶"的个数
- In-place:占用常数内存,不占用额外内存
- Out-place:占用额外内存
- 稳定性:排序后 2 个相等键值的顺序和排序之前它们的顺序相同
步骤
- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。
- 这步做完后,最后的元素会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
优缺点
- 优点:实现简单
- 缺点:性能略差
极端情况
- 最好:数据已经有序
- 最坏:数据全反序
优化策略
- 在每次遍历的时候加上一个检查, 判断是否已经有序,有序就直接退出排序
步骤
- 首先将第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。
- 随着算法执行有序序列逐渐替换掉未排序序列
- 从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置,实现无序向有序的转换
- 如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面。
优缺点
- 优点:实现简单
- 缺点:性能略差
极端情况
- 最好:数据已经有序
- 最坏:数据全反序
优化算法
- 拆半插入
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
步骤
优缺点
- 优点:
- 缺点:
极端情况
- 最好:
- 最坏:
优化算法
-
【 Algorithm 】
-
【 Blog 】
-
【 C 】
-
【 Database 】
-
【 Distributed 】
-
【 FrontEnd 】
- 【 FrontEnd/Frame 】
- 【 FrontEnd/Node 】
- Font
- Hexo
- JavaScript
- LearnPS
- ResponseCode
- SVG
- ViewSolution
- extjs学习笔记
-
【 Functional 】
-
【 Go 】
-
【 Groovy 】
-
【 Java 】
- 【 Java/AdvancedLearning 】
- 【 JavaBasic 】
- 【 JavaCache 】
- 【 JavaCollection 】
- 【 JavaConcurrency 】
- 【 JavaMap 】
- Annotation
- ClassFile
- Collection
- Concurrency
- Deploy
- Exception
- ExtendsAndInterface
- Generics
- IO
- JDBC
- JDKAndJRE
- JMX
- JVM
- Java11
- Java7
- Java8
- JavaNetwork
- JavaReleaseVersion
- JavaWeb
- JvmPerformance
- MQ
- MultipleLanguage
- Proxy
- Reflection
- Serialize
- SyntaxAndType
- Thread
- WebPerformance
- 【 Java/Android 】
- 【 Java/Ecosystem 】
- 【 Java/MSA 】
- 【 Java/Spring 】
- 【 Java/TemplateEngine 】
- 【 Java/Test 】
- 【 Java/Tool 】
- 【 Java/thread 】
- AlibabaJavaStandard
- DesignPattern
- HashMap解析
- Java-NIO
- Java虚拟机
- Log
- MIS
- Quartz
- RESTful
- WebSocket学习笔记
- ZooKeeper学习笔记
- android学习笔记
- 【 Java/AdvancedLearning 】
-
【 Kotlin 】
-
【 Linux 】
- 【 Linux/Alpine 】
- 【 Linux/Arch 】
- 【 Linux/Base 】
- 【 Linux/Centos 】
- 【 Linux/Container 】
- 【 Linux/Debian 】
- 【 Linux/Tool 】
- JavaDevInit
- Linux系统学习
-
【 MyBlog 】
-
【 Python 】
- 【 Python/Tool 】
- Python
- PythonConcurrent
- PythonGUI
- PythonGame
- PythonNet
- PythonOffices
- PythonWeb
- Python基础
- Python核心学习
-
【 Reactive 】
-
【 Rust 】
-
【 Scala 】
-
【 Script 】
-
【 Skills 】
- 【 Skills/Application 】
- 【 Skills/CS 】
- 【 Skills/Cache 】
- 【 Skills/Councurrency 】
- 【 Skills/DevOps 】
- 【 Skills/Document 】
- 【 Skills/Ecology 】
- 【 Skills/Network 】
- 【 Skills/Search 】
- 【 Skills/SoftwareEngineering 】
- 【 Skills/Spider 】
- 【 Skills/Test 】
- 【 Skills/Vcs 】
- 【 Skills/Work 】
- AppManual
- CelebrityQuotes
- Miscellaneous
- Platform
- Problem
- Protobuf
- RegularExpression
- SoftwareDesignEngineer
- Website
-
【 Windows 】