全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Java经典排序算法之插入排序

一、算法原理

插入排序法:所谓插入排序法乃是将一个数目插入该占据的位置。

假设我们输入的是 “53,27,36,15,69,  42” 我们从第二个数字开始,这个数字是27,我们的任务只要看看27有没有正确的位置,我们的做法是和这个数字左边的数字来比,因此我们比较27和53,27比53小,所以我们就交换27和53,原来的排列就变成了“27, 53, 36, 15, 69, 42 ”

接下来,我们看第3个数字有没有在正确的位置。这个数字是36,它的左边数字是53,36比53小,所以我们将36和53交换,排列变成了 “27,36, 53, 15, 69, 42 "我们必须继续看36有没有在正确的位置,36的左边是27,27比36小,36就维持不动了,这时候排序还是“27, 36, 53, 15, 69, 42 "。

再来看第四个数字,这个数字是15,我们将15和它左边的数字相比,都比15大,所以就将15一路往左移动,这时候排序变成了 “15, 27, 36, 53, 69, 42 ”。

再来看第五个数字,这个数字是69,我们将69和它左边的数字相比,都比69小,所以就69维持不动了,这时候排序变成了 “15, 27, 36, 53, 69, 42 ”

最后,我们检查第六个数字,这个数字是42,42必须往左移,一直移到42的左边是36为止,所以我们的排列就变成了 “15, 27, 36, 42 ,53, 69”排序因此完成了。

ps:读者也可以自己打开下面的链接,自己设定要排序的数组,进行排序演练
直接插入排序动画演示

所谓插入排序法,就是检查第i个数字,如果在它的左边的数字比它大,进行交换,这个动作一直继续下去,直到这个数字的左边数字比它还要小,就可以停止了。插入排序法主要的回圈有两个变数:i和j,每一次执行这个回圈,就会将第i个数字放到左边恰当的位置去。

二、算法描述

1、从第一个元素开始,该元素可以认为已经被排序。
2、取出下一个元素,在已经排序的元素序列中从后向前扫描。
3、如果该元素(已排序)大于新元素,则将该元素移到下一位置。
4、重复步骤3,直到找到已排序的元素小于或者大于新元素的位置。
5、将新元素插入到该位置。
6、重复步骤2。

三、效率分析

如果目标是把n个元素的序列升序排列,那么采用插入排序存在最好情况和最坏情况如下。
最好情况:序列已经是升序排列了,在这种情况下,需要进行的比较操作需(n-1)次即可。
最坏情况:序列是降序排列,那么此时需要进行的比较共有n(n-1)/2次。
直接插入排序属于稳定的排序,最坏时间复杂度为O(n^2),最好时间复杂度为O(n),空间复杂度为O(1)。
插入排序的赋值操作是比较操作的次数加上(n-1)次。
因此,插入排序不适合对于数据量比较大的排序应用。

四、代码实现

public class InsertSortTest { 
  public static void InsertSort(int[] source) { 
    int i, j; 
    int insertNode;// 要插入的数据 
    // 从数组的第二个元素开始循环将数组中的元素插入 
    for (i = 1; i < source.length; i++) { 
      // 设置数组中的第2个元素为第一次循环要插入的数据 
      insertNode = source[i]; 
      j = i - 1; 
      // 如果要插入的元素小于第j个元素,就将第j个元素向后移 
      while ((j >= 0) && insertNode < source[j]) { 
        source[j + 1] = source[j]; 
        j--;  
      } 
      // 直到要插入的元素不小于第j个元素,将insertNote插入到数组中 
      source[j + 1] = insertNode; 
      System.out.print("第" + i + "趟排序:"); 
      printArray(source); 
    } 
  } 
 
  private static void printArray(int[] source) { 
    for (int i = 0; i < source.length; i++) { 
      System.out.print("\t" + source[i]); 
    } 
    System.out.println(); 
  } 
 
  public static void main(String[] args) { 
    int source[] = new int[] { 53, 27, 36, 15, 69, 42 }; 
    System.out.print("初始关键字:"); 
    printArray(source); 
    System.out.println(""); 
    InsertSort(source); 
 
    System.out.print("\n\n排序后结果:"); 
    printArray(source); 
  } 
 
} 

五、运行结果

初始关键字:   53 27 36 15 69 42 
 
第1趟排序: 27 53 36 15 69 42 
第2趟排序: 27 36 53 15 69 42 
第3趟排序: 15 27 36 53 69 42 
第4趟排序: 15 27 36 53 69 42 
第5趟排序: 15 27 36 42 53 69 
 
 
排序后结果: 15 27 36 42 53 69 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Java  # 插入排序  # 深入了解Java排序算法  # java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述  # 用java实现冒泡排序算法  # Java实现几种常见排序算法代码  # java冒泡排序算法代码  # 十种JAVA排序算法实例  # Java经典排序算法之归并排序详解  # Java实现八种排序算法详细代码举例  # 变成了  # 升序  # 最坏  # 组中  # 第二个  # 这时候  # 再来  # 就将  # 动了  # 移到  # 都比  # 的是  # 往左  # 第一个  # 下一  # 不适合  # 我们必须  # 会将  # 在这种情况下  # 大家多多 


相关文章: 如何快速使用云服务器搭建个人网站?  如何用IIS7快速搭建并优化网站站点?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  宝塔新建站点报错如何解决?  php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】  视频网站app制作软件,有什么好的视频聊天网站或者软件?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  深入理解Android中的xmlns:tools属性  如何将凡科建站内容保存为本地文件?  如何通过免费商城建站系统源码自定义网站主题与功能?  如何在阿里云虚拟主机上快速搭建个人网站?  网站制作话术技巧,网站推广做的好怎么话术?  制作公司内部网站有哪些,内网如何建网站?  定制建站流程解析:需求评估与SEO优化功能开发指南  如何零成本快速生成个人自助网站?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?    非常酷的网站设计制作软件,酷培ai教育官方网站?  潮流网站制作头像软件下载,适合母子的网名有哪些?  网站制作服务平台,有什么网站可以发布本地服务信息?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  安云自助建站系统如何快速提升SEO排名?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  公众号网站制作网页,微信公众号怎么制作?  如何快速生成专业多端适配建站电话?  平台云上自主建站:模板化设计与智能工具打造高效网站  大学网站设计制作软件有哪些,如何将网站制作成自己app?  免费网站制作appp,免费制作app哪个平台好?  黑客如何通过漏洞一步步攻陷网站服务器?  如何快速搭建响应式可视化网站?  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  英语简历制作免费网站推荐,如何将简历翻译成英文?  网站专业制作公司有哪些,做一个公司网站要多少钱?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?  淘宝制作网站有哪些,淘宝网官网主页?  北京企业网站设计制作公司,北京铁路集团官方网站?  如何快速搭建个人网站并优化SEO?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  建站之星后台管理如何实现高效配置?  建站之星2.7模板快速切换与批量管理功能操作指南  如何选择高性价比服务器搭建个人网站?  常州自助建站费用包含哪些项目?  建站之星安装路径如何正确选择及配置?  Python如何创建带属性的XML节点  如何在服务器上三步完成建站并提升流量?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  建站之星上传入口如何快速找到?  如何在万网ECS上快速搭建专属网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。