首页 > 其他分享 >【插入排序】详细讲解

【插入排序】详细讲解

时间:2023-01-03 20:55:08浏览次数:45  
标签:temp 前面 55 插入排序 交换 99 详细 讲解 data

总体思路

排序流程:

一共十个数排序,先用第二个数55跟第一个数99比较,如果55小于99,那么交换55和99,此时前两个数(即55和99)已经有序了。

接下来用第三个数11跟第二个数99比较,如果11小于99,那么交换11和99,再用第二个数(此时是11)和第一个数55比较,如果11小于55,那么交换11和55,此时前三个数已经有序了。

按照此方法,排序len-1次即可。

抽象流程:

举个例子,假如有十个人,要按照年龄大小排队站好,年龄小的站排头,年龄大的站排尾,实际上这个事就是,第一个人不用动,第二到第十个人,每个人重复一次流程:问前面的人:“嘿,哥们你多大”。如果前面的人比自己年龄小,那么就原地站好结束行动,如果前面的人比自己年龄大,那么就让他站到自己身后。

代码流程:

那么肯定是两层循环嵌套。

第一层循环:代表着从第二到第十个人每个人都要重复一次“找自己位置”的流程

第二层循环:代表着每个人要不断询问前面人的年龄,直到前面的人比自己小或已经到头了为止。

所以接下来考虑一下两层循环的条件。

第一次循环:

//为了更直观的关注循环的实现,就不贴函数了,假设函数传入两个参数,数组data[10]和数组长度length.
int i = 0;
int j = 0;
int temp = 0;//一个临时的值,交换两个数自然需要一个临时的值了。
for (i = 1; i < length; i++)//i = 1代表从第二个人开始,因为第一个人就自己=有序。i < length代表到最后一个人结束
{
    temp = data[i];			//“找自己位置的人”先记下自己的年龄
    //j = 1代表首先询问自己前面一个人的年龄。
    //j >= 0 && temp < data[j] 条件前面说过了,什么时候交换?前面的人比我小,并且还没到头的时候
    //j-- 如果这次询问完并且交换了,那么下一次怎么做?当然是去问问前面的前面那个人多大了,所以j--;
    for(j = i-1; j >= 0 && temp < data[j]; j--)
    {
        //发现自己确实比前面的人年龄大,因此进行交换,否则也进不来这次循环。代码的意思是,自己的位置被前面的人占了。
        data[j+1] = data[j];  //此处很多新手疑问,为什么不是data[j] = data[i]直接赋值,请看最后的说明。
    }
    //自己(temp就是记下的自己的年龄嘛)占到前面的人的位置,完成交换。
    data[j] = temp;
}

说明一下,为什么不是data[j] = data[i]直接赋值?

两个值交换必然经过一直中间变量,此话是废话,废就废在懂的人不用说,不懂的人说了也不懂,因此我要举个例子,请诸位静听。
假如你在上学,老师让你和你的同桌换个座位,请问怎么换?

流程必然是:1、有一个人先腾出自己的座位 2、另一个人坐上去 3、让出座位的人坐到另一个人的位置

想象一下这个场景,如果你腾出自己的位置,在你等你的同桌坐到你座位上的过程中,你站在哪里?你站在旁边对不对?这个旁边这片空间,就是temp。

只不过人比机器聪明,让你忽略了原来你让出位置并且站在了其他的空间,而你只关注于你和同桌交换的结果。

但是机器不是,如果你不去temp等着,你的同桌就会把你吃了,然后你就消失了。

再想象一下,一个长方形盒子2立方米的体积,有两个1立方米的正方体放进去,严丝合缝没有空间剩余,不利用外界空间的情况下,两个盒子就是死的,谁也动不了,因为没空间给他活动。如果你想交换两个正方体的位置,你只能先把一个拿出来,拿到一个temp空间中,才能完成交换。

时间复杂度分析

插入排序势必要比较len-1次。

最好的情况就是天然有序,每个人询问前面的人的年龄,发现比自己小,每个人都不用动。

最坏的情况是每个人都把前面的人比较一遍。

假如十个人排序,最好的情况只需要比较9次,时间复杂度O(n);最坏的情况需要比较(0+9)*10/2,时间复杂度O(n2).

空间复杂度

O(1)

稳定性

稳定(指值相同的元素,排序前后位置不变)

标签:temp,前面,55,插入排序,交换,99,详细,讲解,data
From: https://www.cnblogs.com/xiaowangshu1/p/17023359.html

相关文章

  • bbs项目(部分讲解)
    首页导航条和轮播图创建index.html,添加路由,get请求时返回index.html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>index</title>......
  • 红队渗透靶场之prime1.0(超详细!)
    靶场考察知识WordpressWordPress是一个免费的开源内容管理系统(CMS),可以用来创建和管理网站或博客。它是由PHP语言和MySQL数据库构建的,并且拥有大量的插件和主题,可以让您轻......
  • Shell字符串截取(非常详细)
    一、从指定位置开始截取1)从字符串的左边开始截取(下标计数从0开始)如果想从字符串的左边开始计数,那么截取字符串的具体格式如下:${string:start:length}其中,string是......
  • CH334、CH335 USB2.0HUB详细说明
    简介USB HUB又称USB集线器,主要用于USB主机端口扩展,广泛应用于计算机,笔记本,及周边应用。CH334、CH335是符合 USB2.0 协议规范的高性能MTT 4 端口 USB2.0  HUB 控......
  • 2022最详细最快微信聊天记录备份&导出方案
     12-1在有些情况下,比如需要换电脑的时候,或者需要对某些重要的聊天对话做一些备份,就凭微信本身的功能,是不行的,微信根本不提供聊天记录导出功能。使用本文章的方法,可以自动地......
  • 手把手带你开发starter,点对点带你讲解原理
    京东物流孔祥东___________/____|(_)|_\|||(________________||......
  • .gitattributes 作用详细讲解
    https://blog.csdn.net/qq_35425070/article/details/106883833  *.fbxfilter=lfsdiff=lfsmerge=lfs-text*.fbXfilter=lfsdiff=lfsmerge=lfs-text*.fBxfi......
  • 手把手带你开发starter,点对点带你讲解原理
    #####京东物流孔祥东```___________/____|(_)|_\|||(__________......
  • jquery的each()详细介绍
    each()方法能使DOM循环结构简洁,不容易出错。each()函数封装了十分强大的遍历功能,使用也很方便,它可以遍历一维数组、多维数组、DOM,JSON等等在javaScript开发过程中......
  • 【YOLO学习笔记——数据集】之一YOLO数据集制作1(含LabelImg工具讲解)
    前言一、综述YOLO有自己训练好的数据集,在YOLOv2中,数据集可检测的类别达9000种以上,但是9000毕竟不是全部,它能涵盖大部分的物体识别,但是可能对于某些用户来说是不够的,所以我......