博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
看完这个你还不会 插入排序 么
阅读量:6148 次
发布时间:2019-06-21

本文共 867 字,大约阅读时间需要 2 分钟。

前言

由于LeetCode上的算法题很多涉及到一些基础的数据结构,为了更好的理解后续更新的一些复杂题目的动画,推出一个新系列 -----《图解数据结构》,主要使用动画来描述常见的数据结构和算法。本系列包括十大排序、堆、队列、树、并查集、图等等大概几十篇。

你可以关注公众号 五分钟学算法 获取更多排序内容。

插入排序

插入排序的代码实现虽然没有冒泡排序和选择排序那么简单粗暴,但它的原理应该是最容易理解的了,因为只要打过扑克牌的人都应该能够秒懂。插入排序是一种最简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

算法步骤

  1. 将第一待排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。

  2. 从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置。(如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面。)。

来源:

算法演示

排序动画过程解释

  1. 一开始左端数字已经排序,数字 5 不动

  2. 然后,取出剩余未操作的左端数字 3

  3. 将其与已经操作的左侧数字相比较

  4. 如果左边的数字较大,则交换两个数字

  5. 这种情况下,由于 5 大于 3 ,所以交换两个数字

  6. 重复此操作,直到出现一个较小的数字或者数字到达左端

  7. 数字 3 已经完成排序

  8. 接下来,和之前一样取出剩余未操作的左端数字 4

  9. 与其相邻的左边数字进行比较

  10. 这种情况下,由于 5 大于 4 ,所以交换两个数字

  11. 继续操作,由于 3 小于 4 ,即出现了更小的数字,所以 4 停止移动

  12. 数字 4 已经完成排序

  13. 重复相同的操作,直到所有的数字完成排序

代码实现

为了更好的让读者用自己熟悉的编程语言来理解动画,笔者将贴出多种编程语言的参考代码,代码全部来源于网上。

C++代码实现

Java代码实现

Python代码实现

JavaScript代码实现

如果你是iOS开发者,可以在GitHub上 获取更直观可调试运行的源码。

你可以关注公众号 五分钟学算法 获取更多排序内容。

转载地址:http://phmya.baihongyu.com/

你可能感兴趣的文章
智力大冲浪
查看>>
JSONP实现跨域
查看>>
虚拟机VMware 9安装苹果MAC OSX 10.8图文教程
查看>>
微信小程序开发-框架
查看>>
redo、undo、binlog的区别
查看>>
DropDownList 控制日期控件显示格式
查看>>
RecycleView设置顶部分割线(记录一个坑)
查看>>
汉字转拼音 (转)
查看>>
Machine Learning Techniques -6-Support Vector Regression
查看>>
会计基础_001
查看>>
ajax请求拿到多条数据拼接显示在页面中
查看>>
小程序: 查看正在写的页面
查看>>
Jenkins持续集成环境部署
查看>>
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
摄像机与绕任意轴旋转
查看>>
rsync 服务器配置过程
查看>>
预处理、const与sizeof相关面试题
查看>>
爬虫豆瓣top250项目-开发文档
查看>>
Elasticsearch增删改查
查看>>