Python排序算法(四)——插入排序
有趣的事,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排序算法(四)——插入排序相关推荐
- python 排序算法:插入排序
摘自:python 排序算法--插入排序 适用场景:一个新元素需要插入到一组已经是有序的数组中,或者是一组基本有序的数组排序. 比较性:排序时元素之间需要比较,所以为比较排序. 稳定性:从代码我们可以 ...
- python排序算法——插入排序
python排序算法--插入排序 文章目录 python排序算法--插入排序 一.前言 二.描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序算法是指 ...
- Python排序算法总结
Python排序算法总结 递归 在正式讲算法之前,先介绍一下递归.递归是一种解决问题的思路. 特点 调用自身 必须有一个明确的结束条件,比如if... 递归的两个阶段: 递推(压栈):到某个阶段,该阶 ...
- python排序算法——希尔排序(附代码)
python排序算法--希尔排序 文章目录 python排序算法--希尔排序 一.前言 二.算法描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序算法 ...
- Java常见排序算法之插入排序
一.概述 本节由小千给大家分享Java常见排序算法之插入排序,之前我们说过排序是算法中的一部分.所以我们学习排序也是算法的入门,为了能让大家感受到排序是算法的一部分,我举个例子证明一下:比如麻将游戏, ...
- 带你掌握4种Python 排序算法
摘要:在编程里,排序是一个重要算法,它可以帮助我们更快.更容易地定位数据.在这篇文章中,我们将使用排序算法分类器对我们的数组进行排序,了解它们是如何工作的. 本文分享自华为云社区<Python ...
- Python排序算法[二]:测试数据的迷雾散去
算法试验中不仅仅要尝试使用不同的写法,更要注意测试所用数据的规律性,它们都会直接影响测试结果. 在上一篇文章<Python 排序算法[一]:令你茅塞顿开,却又匪夷所思>中我们学习了排序算法 ...
- python排序算法——归并排序(附代码)
python排序算法 --归并排序 文章目录 python排序算法 --归并排序 一.前言 二.算法描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序 ...
- python排序算法 ——冒泡排序(附代码)
python排序算法 --冒泡排序 文章目录 python排序算法 --冒泡排序 一.前言 二.算法描述 三.代码实现 总结 一.前言 相关知识来自<python算法设计与分析>.初级排序 ...
- 【算法系列 | 2】深入解析排序算法之——插入排序
序言 你只管努力,其他交给时间,时间会证明一切. 文章标记颜色说明: 黄色:重要标题 红色:用来标记结论 绿色:用来标记一级论点 蓝色:用来标记二级论点 决定开一个算法专栏,希望能帮助大家很好的了解算 ...
最新文章
- 【Python自动化测试】setuptools
- 菜鸟学习日记:跟我一起学office2007之Excel【02基础篇】04Excel基础知识二
- python怎么打日志_怎样调试 日志 python 代码
- java连接摄像头_Java实现 海康摄像头抓拍图像(示例代码)
- iOS开发总结(A0)- Localization
- 基于代码、社区,两步成为开源赢家!
- php 读取数据库信息,php读取数据库信息的几种方法
- the import XXXX cannot be resolved 解决方法
- C++ 常见错误(03) —— cout输出图像路径
- 20道必须掌握的C++面试题
- 同事线上埋的这个坑,我整整找了3天3夜
- Eclipse切换IDE界面语言
- Windowsmobile 的第一篇 为什么选择windows mobile 的分析
- html播放器参数,Windows Media Player网页播放器及其参数含义
- matlab代码:基于主从博弈的智能小区代理商定价策略及电动汽车充电管理
- 大战略游戏:统治者:罗马 for Mac
- SpringCache报错解决
- 王者荣耀英雄皮肤官方高清图片爬虫
- ORB SLAM2源码解读(三):Frame类
- java label对齐方式_java – 在BorderLayout中对齐JLabel和JTextField
热门文章
- ElmentUI数据表格 序号
- Element表格序号问题
- keil5实现51单片机和stm32同时编辑
- Unity遍历文件夹及其文件
- K Simple question (第十届山东理工大学ACM网络编程擂台赛 正式赛)
- 【精读论文】2015-BMVC-Learning Deep Representations of Appearance and Motion for Anomalous Event Detection
- 大行bya412和java513_真实解密大行bya412和k3区别在哪里?哪款最好?老司机透漏评测...
- 毕业论文文献综述写作技巧,超级详细!
- DNS服务器分类与bind-chroot服务配置
- renderdoc 抓google地图