数据结构 | 排序

插入排序


直接插入排序(空间复杂度为1,排序后稳定)

思路:

在待排序的元素中,假设前n-1个元素已有序,现将第n个元素插入到前面已经排好的序列中,使得前n个元素有序。按照此法对所有元素进行插入,直到整个序列有序。

但我们并不能确定待排元素中究竟哪一部分是有序的,所以我们一开始只能认为第一个元素是有序的,依次将其后面的元素插入到这个有序序列中来,直到整个序列有序为止。

时间复杂度:最坏情况下为O(N*N),此时待排序列为逆序,或者说接近逆序
      最好情况下为O(N),此时待排序列为升序,或者说接近升序。
空间复杂度:O(1)


折半查找(数列应该有顺序)

时间复杂度(减少比较次数,而记录移动的次数不变)


希尔排序(缩小增量法)


交换排序


冒泡排序


快速排序


选择排序


直接选择排序


归并排序

动图演示:


基数排序

总结


时间及空间复杂度

相关推荐
程序员东岸11 小时前
数据结构杂谈:双向链表避坑指南
数据结构·链表
Shinom1ya_11 小时前
算法 day 46
数据结构·算法
9523611 小时前
数据结构-链表
java·数据结构·学习
小龙报13 小时前
算法通关指南:数据结构和算法篇 --- 队列相关算法题》--- 1. 【模板】队列,2. 机器翻译
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
晨非辰13 小时前
【数据结构初阶】--从排序算法原理分析到代码实现操作,参透插入排序的奥秘!
c语言·开发语言·数据结构·c++·算法·面试·排序算法
三川69814 小时前
排序算法介绍
数据结构·算法·排序算法
学编程就要猛1 天前
数据结构初阶:Java中的Stack和Queue
数据结构
是苏浙1 天前
零基础入门C语言之C语言实现数据结构之顺序表
c语言·开发语言·数据结构
星释1 天前
Rust 练习册 :Matching Brackets与栈数据结构
数据结构·算法·rust
逐步前行1 天前
C数据结构--排序算法
c语言·数据结构·排序算法