【11.14】直接插入排序

基本思想为把数组a中n个元素看成包含一个元素a[0]的有序表及其余元素组成的无序表
每次从无序表中选出第一个元素,插入到有序表合适位置,插入次数为n-1次,完成排序。

核心算法思路如下:
> 无序表每次a[i]先和前面一个数据a[i-1]比较,如果a[i] > a[i-1]
> 说明a[0…i]也是有序的,无须调整。否则就令j=i-1,temp=a[i]。
> 然后一边将数据a[j]向后移动一边向前搜索,
> 当有数据a[j]<a[i]时停止并将temp放到a[j + 1]处。
详细实现代码如下:

捕获.PNG
     * 再对将a[j]插入到前面a[0…j-1]的有序区间所用的方法进行改写
 * 用数据交换代替数据后移。如果a[j]前一个数据a[j-1] > a[j],
 * 就交换a[j]和a[j-1],再j--直到a[j-1] <= a[j]。
 * 这样也可以实现将一个新数据新并入到有序区间。

详细实现代码如下:

捕获2.PNG

完全代码及测试结果如下:

捕获4.PNG
捕获3.PNG

不足之处及改进欢迎指正!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 1,369评论 0 1
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,271评论 0 2
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,742评论 0 15
  • 最尴尬的电影,最最尴尬的电影,莫过于期待过大的何炅老师的《栀子花开》,简直了,我以为何老师的才华,剧本的质量和水平...
    金耳er阅读 286评论 2 5
  • 轻柔唤醒天空的眼睛 脚底下乖巧的天地 棉絮幽幽如梦 是蛮荒的呓语 穿越世外桃源 仙乐和飞天的相遇 时光安静 创世纪...
    稻城阳光阅读 185评论 10 15