有趣的事,Python永远不会缺席!

如需转发,请注明出处:小婷儿的python  https://www.cnblogs.com/xxtalhr/p/10787464.html

一、插入排序(Insertion-Sort)

  插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

  把n个待排序的元素看成为一个有序表和一个无序表。开始时有序表中只包含1个元素,无序表中包含有n-1个元素,排序过程中每次从无序表中取出第一个元素,将它插入到有序表中的适当位置,使之成为新的有序表,重复n-1次可完成排序过程。

1、原理

  • 从第二个元素开始和前面的元素进行比较,如果前面的元素比当前元素大,则将前面元素 后移,当前元素依次往前,直到找到比它小或等于它的元素插入在其后面

  • 然后选择第三个元素,重复上述操作,进行插入

  • 依次选择到最后一个元素,插入后即完成所有排序

2、举例

  举个例子,假设我现在有一个数列[11, 99, 33 , 69, 77, 88, 55, 11, 33, 36,39, 66, 44, 22]需要使用插入排序,我们来看看使用插入排序的详细步骤:

  • 首先第二个元素99和前面的元素11比较,99>11,第一轮完了,列表是 1 [11, 99, 33 , 69, 77, 88, 55, 11, 33, 36,39, 66, 44, 22]
  • 然后,33作为比较元素,和前面的元素99比较,11<33<99交换位置,33插入到11和99之间,列表为 1 [11, 33, 99, 69, 77, 88, 55, 11, 33, 36,39, 66, 44, 22]
  • 接着,33<69<99交换位置,列表变为    1 [11, 33, 69, 99, 77, 88, 55, 11, 33, 36,39, 66, 44, 22]
  • 以此类推,69<77<99,77插入到69和99之间,列表变为   1 [11, 33, 69, 77, 99, 88, 55, 11, 33, 36,39, 66, 44, 22]
  • 77<88<99, 88插入到77和99之间,列表变为    1 [11, 33, 69, 77, 88, 99, 55, 11, 33, 36,39, 66, 44, 22]
  • 33<55<69<77<88<99,55插入到33和69之间,列表变为   1 [11, 33, 69, 77, 88, 99, 55, 11, 33, 36,39, 66, 44, 22]
  • 。。。。。。。
  • 最终得到列表  1 [11, 11, 22, 33, 33, 36, 39, 44, 55, 66, 69, 77, 88, 99]

注:从第二个元素开始,以此和前面的元素比较,找出相应位置插入。

二、代码

  代码用jupyternotebook实现

 1 def insertion_sort(arr):
 2     """插入排序"""
 3     # 第一层for表示循环插入的遍数
 4     for i in range(1, len(arr)):
 5         # 设置当前需要插入的元素
 6         current = arr[i]
 7         # 与当前元素比较的比较元素
 8         pre_index = i - 1
 9         while pre_index >= 0 and arr[pre_index] > current:
10             # 当比较元素大于当前元素则把比较元素后移
11             arr[pre_index + 1] = arr[pre_index]
12             # 往前选择下一个比较元素
13             pre_index -= 1
14         # 当比较元素小于当前元素,则将当前元素插入在 其后面
15         arr[pre_index + 1] = current
16     return arr
17
18 insertion_sort([11, 11, 22, 33, 33, 36, 39, 44, 55, 66, 69, 77, 88, 99])
19
20
21 # 返回结果[11, 11, 22, 33, 33, 36, 39, 44, 55, 66, 69, 77, 88, 99]

三、特点

    插入排序的适用场景:一个新元素需要插入到一组已经是有序的数组中,或者是一组基本有序的数组排序

  • 比较性:排序时元素之间需要比较,所以为比较排序
  • 稳定性:从代码我们可以看出只有比较元素大于当前元素,比较元素才会往后移动,所以相同元素是不会改变相对顺序
  • 时间复杂度:插入排序同样需要两次循坏一个一个比较,故时间复杂度也为O(n^2)
  • 空间复杂度:只需要常数个辅助单元,所以空间复杂度也为O(1)
  • 记忆方法:想象成在书架中插书:先找到相应位置,将后面的书往后推,再将书插入

结果   

  Successfully !!!

  有趣的事,Python永远不会缺席!还不来加我,瞅什么瞅。

Python排序算法(四)——插入排序相关推荐

  1. python 排序算法:插入排序

    摘自:python 排序算法--插入排序 适用场景:一个新元素需要插入到一组已经是有序的数组中,或者是一组基本有序的数组排序. 比较性:排序时元素之间需要比较,所以为比较排序. 稳定性:从代码我们可以 ...

  2. python排序算法——插入排序

    python排序算法--插入排序 文章目录 python排序算法--插入排序 一.前言 二.描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序算法是指 ...

  3. Python排序算法总结

    Python排序算法总结 递归 在正式讲算法之前,先介绍一下递归.递归是一种解决问题的思路. 特点 调用自身 必须有一个明确的结束条件,比如if... 递归的两个阶段: 递推(压栈):到某个阶段,该阶 ...

  4. python排序算法——希尔排序(附代码)

    python排序算法--希尔排序 文章目录 python排序算法--希尔排序 一.前言 二.算法描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序算法 ...

  5. Java常见排序算法之插入排序

    一.概述 本节由小千给大家分享Java常见排序算法之插入排序,之前我们说过排序是算法中的一部分.所以我们学习排序也是算法的入门,为了能让大家感受到排序是算法的一部分,我举个例子证明一下:比如麻将游戏, ...

  6. 带你掌握4种Python 排序算法

    摘要:在编程里,排序是一个重要算法,它可以帮助我们更快.更容易地定位数据.在这篇文章中,我们将使用排序算法分类器对我们的数组进行排序,了解它们是如何工作的. 本文分享自华为云社区<Python ...

  7. Python排序算法[二]:测试数据的迷雾散去

    算法试验中不仅仅要尝试使用不同的写法,更要注意测试所用数据的规律性,它们都会直接影响测试结果. 在上一篇文章<Python 排序算法[一]:令你茅塞顿开,却又匪夷所思>中我们学习了排序算法 ...

  8. python排序算法——归并排序(附代码)

    python排序算法 --归并排序 文章目录 python排序算法 --归并排序 一.前言 二.算法描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序 ...

  9. python排序算法 ——冒泡排序(附代码)

    python排序算法 --冒泡排序 文章目录 python排序算法 --冒泡排序 一.前言 二.算法描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序 ...

  10. 【算法系列 | 2】深入解析排序算法之——插入排序

    序言 你只管努力,其他交给时间,时间会证明一切. 文章标记颜色说明: 黄色:重要标题 红色:用来标记结论 绿色:用来标记一级论点 蓝色:用来标记二级论点 决定开一个算法专栏,希望能帮助大家很好的了解算 ...

最新文章

  1. 【Python自动化测试】setuptools
  2. 菜鸟学习日记:跟我一起学office2007之Excel【02基础篇】04Excel基础知识二
  3. python怎么打日志_怎样调试 日志 python 代码
  4. java连接摄像头_Java实现 海康摄像头抓拍图像(示例代码)
  5. iOS开发总结(A0)- Localization
  6. 基于代码、社区,两步成为开源赢家!
  7. php 读取数据库信息,php读取数据库信息的几种方法
  8. the import XXXX cannot be resolved 解决方法
  9. C++ 常见错误(03) —— cout输出图像路径
  10. 20道必须掌握的C++面试题
  11. 同事线上埋的这个坑,我整整找了3天3夜
  12. Eclipse切换IDE界面语言
  13. Windowsmobile 的第一篇 为什么选择windows mobile 的分析
  14. html播放器参数,Windows Media Player网页播放器及其参数含义
  15. matlab代码:基于主从博弈的智能小区代理商定价策略及电动汽车充电管理
  16. 大战略游戏:统治者:罗马 for Mac
  17. SpringCache报错解决
  18. 王者荣耀英雄皮肤官方高清图片爬虫
  19. ORB SLAM2源码解读(三):Frame类
  20. java label对齐方式_java – 在BorderLayout中对齐JLabel和JTextField

热门文章

  1. ElmentUI数据表格 序号
  2. Element表格序号问题
  3. keil5实现51单片机和stm32同时编辑
  4. Unity遍历文件夹及其文件
  5. K Simple question (第十届山东理工大学ACM网络编程擂台赛 正式赛)
  6. 【精读论文】2015-BMVC-Learning Deep Representations of Appearance and Motion for Anomalous Event Detection
  7. 大行bya412和java513_真实解密大行bya412和k3区别在哪里?哪款最好?老司机透漏评测...
  8. 毕业论文文献综述写作技巧,超级详细!
  9. DNS服务器分类与bind-chroot服务配置
  10. renderdoc 抓google地图