数据结构--插入排序

一、算法思想:

每次将一个待排序的记录按其关键字大小插入到前面已经排好序的子序列中

例如:把13拿出来不断的进行比较再左移

二、代码实现(一):每一个元素拿出来与它的前后进行对比

用 temp 存储当前拿出来的元素:防止操作时候被覆盖

注意循环中的:

复制代码
for(j=i-1;j>=0 && A[j] > temp; --j)
{
    A[j+1] = A[j]  //j+1 == i(当前处理的元素位置)  j == i-1(这个大于当前处理元素的元素位置)
 }                 //前一位赋值给后一位
  
 A[j+1] = temp

代码实现(二):哨兵实现

把当前处理的元素放到最开头 A0 的位置

三、算法的空间复杂度:

O(1): 因为我们用的方法不是temp就是哨兵,都是常数级别的,所以所占的空间就是1

四、算法的时间复杂度:

O(n) : 需要 n-1 趟的对比判断------最好的情况下

O(n²):------ 原本就是逆序排列的 ------最坏的情况下

五、优化操作

(图中蓝色数字是要插入的元素,

绿色是已经有的序列,

红色是复制要插入的元素)

折半查找

例如处理60 的时候

第一个被检查的位置是50

50 < 60

low = mid + 1

mid = (low + high) / 2 -----检查的是60

60 == 60 ------- 当找到当前处理元素的值相同时,继续在mid所指右边查找

当high < low 的时候,停止查找

六、对链表的插入排序

相关推荐
郝学胜_神的一滴25 分钟前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
数据结构·算法
asdzx6726 分钟前
Python 优雅解析 Excel:从原生行列到强类型对象的三层数据结构演进
数据结构·python·excel
是苏浙34 分钟前
Java实现链表2
java·开发语言·数据结构
KobeSacre42 分钟前
ThreadLocal 源码
数据结构
少司府1 小时前
C++基础入门:_stack_queue 底层奥秘
开发语言·数据结构·c++·栈和队列·queue·stack
牛油果子哥q1 小时前
unordered_set / unordered_map 底层哈希表精讲,哈希原理、哈希冲突、链地址法、源码结构、有序与无序容器终极选型全解
数据结构·算法·哈希算法·散列表
进击的荆棘1 小时前
优选算法——优先级队列
数据结构·c++·算法·leetcode·优先级队列
牛油果子哥q1 小时前
哈希表经典刷题模型与布隆过滤器精讲,哈希查重、哈希计数、双哈希映射、误判原理与工业级落地应用
数据结构·算法·哈希算法·散列表
2601_961845152 小时前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
前进吧-程序员2 小时前
反转链表完全指南:辅助容器、三指针、头插法
数据结构·c++·链表