返回顶部
首页 > 资讯 > 精选 >好程序员Java培训分享Java常见排序算法之插入排序
  • 613
分享到

好程序员Java培训分享Java常见排序算法之插入排序

2023-06-02 08:06:47 613人浏览 八月长安
摘要

好程序员Java培训分享Java常见排序算法之插入排序,之前我们说过排序是算法中的一部分。所以我们学习排序也是算法的入门,为了能让大家感受到排序是算法的一部分,我举个例子证明一下:比如麻 将游戏,发完牌之后需要对手上的牌进行排序,大家想想,

程序员Java培训分享Java常见排序算法之插入排序,之前我们说过排序是算法中的一部分。所以我们学习排序也是算法的入门,为了能让大家感受到排序是算法的一部分,我举个例子证明一下:比如麻 将游戏,发完牌之后需要对手上的牌进行排序,大家想想,麻 将排序如何排呢?它有什么特点呢?而且在摸牌打 牌的过程中,我们要不断的排序,如何排序呢?选择什么排序算法最快呢?

以上这种情况我们就可以分析选择哪种排序算法更高效。比如下图已经有一副固定顺序的牌了:

好程序员Java培训分享Java常见排序算法之插入排序

此时轮到我们摸牌,摸到的牌如下:

好程序员Java培训分享Java常见排序算法之插入排序

此时,要将这个“三同”放到上面的一副牌中,就存在如下规律:

正常“3同”应该放到“2同”和”4同“中间。

跟其他花色的牌没有关系,甚至跟”5同“也没有关系。只需要把”3同“放到”2同“和”4同“中间就行。至于”2同”和”4同”在哪里不要紧。

我们前面学习了选择排序,如果使用选择排序对上面这副牌进行排序是否合适呢?显然是不合适的,因为选择排序必须从“七万”开始比较,选择最小牌跟头一张牌交换位置,依次类推。但是此处麻 将牌的“3同”跟”七万“没有关系,不需要影响”7万“。所以使用选择排序不合适,因为时间负责度很高;此处使用插入排序会更好,什么是插入排序呢?就是本节需要介绍的内容。

二、插入排序

插入排序属于简单排序的一种,通常指的简单排序只是因为其算法思路比较容易理解,不代表其用途很简单。为了让大家掌握插入排序,我们先看看插入排序的原理。

2.1、插入排序的原理

首先有一个待排序的数组如下:

好程序员Java培训分享Java常见排序算法之插入排序

以上数组中只有一个数字0的顺序需要排列,其他数字的顺序都是对的。这种数组使用插入排序的效率更高,下面介绍此数组使用插入排序的流程。

先比较1和2,如果2比1小则交换位置。否则不交换位置。此数组不需要交换位置。

好程序员Java培训分享Java常见排序算法之插入排序

再比较2和3,如果3比2小,则交换位置。但是实际3比2大所以不交换位置,保持不变。

好程序员Java培训分享Java常见排序算法之插入排序

同理,3和4比较也不需要交换位置,保持不变

好程序员Java培训分享Java常见排序算法之插入排序

接来下,4和0比较,0小于4,所以交换位置

好程序员Java培训分享Java常见排序算法之插入排序

交换位置之后的数组如下:

好程序员Java培训分享Java常见排序算法之插入排序

因为3的邻居发生变化,所以3和0再次比较,0比3小,交换位置,交换之后的数组如下:

好程序员Java培训分享Java常见排序算法之插入排序

依次类推,0分别和2交换位置之后的数组如下:

好程序员Java培训分享Java常见排序算法之插入排序

0再和1交换位置的数组如下:

好程序员Java培训分享Java常见排序算法之插入排序

这样一个数组的顺序就对了,但是循环还没有完成,因为我们刚才仅仅循环到数字4这个位置,数字5还没有比较。

最后比较4和5,如果5比4小则交换位置,但是5比4大,所以位置不变。数组循环完毕,最终排序如下:

好程序员Java培训分享Java常见排序算法之插入排序

上面就是插入排序的原理。

2.2、插入排序和选择排序的区别

比如就上面这个例子而言,插入排序是将0从索引为4的位置移动到索引3、2、1、0,最终才算结束。而选择排序是找到最小的值0,直接跟1进行交换,0到1的位置,1到0的位置。大家可以翻看前面关于选择排序的介绍。

三、插入排序的代码实现

以下是java代码的实现:

public static void alGorithm5(){

//原始数组

int[] array={1,2,3,4,0,5};

//数组的长度

int length=array.length;

//对数组进行遍历 for (int i = 0; i < length; i++) {

//第二个循环仅仅是将当前数据跟自己左边的数字进行比较,如果小于左边数字则交换位置,否则位置不变。

for (int j = i; j > 0 && array[j]<array[j-1]; j--) {

int temp = 0;

temp = array[j-1];

array[j-1]=array[j];

array[j]=temp;

}

}

//将排好序的数组打印输出

for (int i = 0; i < length; i++) {

System.out.print(array[i]+",");

}

}

以上是插入排序的java代码实现,代码中的第二个for循环是重点,第二个for循环是只比较当前数据左边的值,如果比左边的值小则交换位置,否则位置不变。

3.1 插入排序的时间复杂度

插入排序的时间复杂度有两种:

当数组本身是有序的,比如{1,2,3,4,5},则采用插入排序的时间复杂度是O(n)。原因:如果数组本身是有序,插入排序需要每两个挨着的数字进行比较一次,总共比较N-1次,所以时间复杂度是O(n)。

当数组是无序的,最坏的情况下需要比较(n^2)/2次,所以时间复杂度是O(n^2)。

四、总结

根据插入排序的时间复杂度来看,插入排序适合如下类型的数组:

数组中的每一个元素距离其最终的位置都不远。比如{1,0,2,3,4,5},这个数组中0最终位置应该是头1个位置,0此时的位置距离1位置不远。

一个有序的大数组中融入一个小数组。比如有序大数组{1,2,3,4,5,6},融入一个小数组{0,1}。

数组中只有几个元素的位置不正确。

上述这三种情况的数组适合使用插入排序算法。打过麻 将的同学想想,打麻 将过程中不停地摸牌、打 牌、整理牌的过程是不是就是一次插入排序呢!

排序是算法的基础,排序的用途很多。看完本节内容之后,大家不妨自己动手写个代码将无需的扑 克 牌进行排序,看更适合哪种排序算法。

--结束END--

本文标题: 好程序员Java培训分享Java常见排序算法之插入排序

本文链接: https://lsjlt.com/news/229559.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 好程序员Java培训分享Java常见排序算法之插入排序
    好程序员Java培训分享Java常见排序算法之插入排序,之前我们说过排序是算法中的一部分。所以我们学习排序也是算法的入门,为了能让大家感受到排序是算法的一部分,我举个例子证明一下:比如麻 将游戏,发完牌之后需要对手上的牌进行排序,大家想想,...
    99+
    2023-06-02
  • 排序算法图解之Java插入排序
    目录1.插入排序简介2.插入排序思想及图解3.插入排序代码实现1.插入排序简介 插入排序,一般也被称为直接插入排序。对于少量元素的排序,它是一个有效的算法。插入排序是一种最简单的排序...
    99+
    2022-11-13
    Java 插入排序算法 Java插入排序 Java 排序算法
  • C语言常见排序算法之插入排序(直接插入排序,希尔排序)
    目录前言一、直接插入排序1.1 基本思想1.2 算法思想1.3 程序实现1.4 直接插入排序的总结二、希尔排序2.1 算法思想2.2 程序实现2.3 希尔排序的特征总结前言...
    99+
    2024-04-02
  • 好程序员Java培训分享Java程序员技能提升指南
      好程序员Java培训分享Java程序员技能提升指南,软件工程是计算机领域发展最快的学科分支之一,在所有软件开发类人才的需求中Java工程师的需求量占软件工程所有岗位需求的60~70%。巨大的企业需求和庞大的人才基数也必然产生激励的就业竞...
    99+
    2023-06-02
  • Java 常见排序算法代码分享
    目录1. 冒泡排序2. 选择排序3. 插入排序4. 快速排序5. 归并排序6. 希尔排序6.1 希尔-冒泡排序(慢)6.2 希尔-插入排序(快)7. 堆排序8. 计数排序9. 桶排序...
    99+
    2024-04-02
  • JAVA十大排序算法之插入排序详解
    目录插入排序代码实现动图演示代码实现时间复杂度算法稳定性总结插入排序 当我们在玩扑克牌的时候,总是在牌堆里面抽取最顶部的一张然后按顺序在手中排列。 插入排序是指在待排序的元素中,假设...
    99+
    2024-04-02
  • Java 十大排序算法之插入排序刨析
    目录插入排序原理插入排序API设计插入排序代码实现插入排序的时间复杂度分析插入排序原理 ①把所有元素分成已排序和未排序两组 ②找到未排序组的第一个元素,向已经排序的组中进行插入 ③倒...
    99+
    2024-04-02
  • Java中插入排序算法之希尔排序+直接插入排序的示例分析
    这篇文章给大家分享的是有关Java中插入排序算法之希尔排序+直接插入排序的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。希尔排序在介绍希尔排序之前,先了解一下直接插入排序一、直接插入排序1. 单趟排序x插...
    99+
    2023-06-25
  • 好程序员Java培训分享Java初学者必读
      好程序员Java培训分享Java初学者必读,近年来各种各样的编程语言不断崛起,但唯有Java是牢牢占据着老大的位置,目前几乎90%以上的大中型互联网应用系统在服务器端开发首选Java。因此,也是吸引了不少年轻人投入到Java的学习之中。...
    99+
    2023-06-02
  • 好程序员Java培训分享之RMI与RPC的区别
      好程序员Java培训分享之RMI与RPC的区别,随着java技术学习的不断深入,越来越觉得保持初心是多么重要,无论我们学到哪个程度,在学习的时候始终保持初学者的心态,才能在自己的技术之上实现突破!  今天有点像鸡汤,回归正题,继续更新我...
    99+
    2023-06-02
  • 插入排序算法之希尔排序+直接插入排序
    目录希尔排序一、直接插入排序1. 单趟排序2. 直接插入排序二、希尔排序三、测试希尔排序和直接插入排序性能希尔排序 在介绍希尔排序之前,先了解一下直接插入排序 一、直接插入排序 1....
    99+
    2024-04-02
  • 好程序员web前端培训分享JavaScript学习笔数组的排序
      好程序员web前端培训分享JavaScript学习笔数组的排序,排序,就是把一个乱序的数组,通过我们的处理,让他变成一个有序的数组,今天我们讲解两种方式来排序一个数组 冒泡排序 和 选择排序冒泡排序·&nb...
    99+
    2023-06-03
  • 排序算法之插入排序法解析
    目录什么是插入排序法算法优化心得体会什么是插入排序法 插入排序法是一种简单但有效的排序算法,其基本思想是将一个待排序的元素逐个插入到已经排好序的元素序列中,直至所有元素都被插入完成,...
    99+
    2023-08-08
    排序算法 插入排序法
  • 分析Java排序算法之希尔排序
    这篇文章主要介绍“分析Java排序算法之希尔排序”,在日常操作中,相信很多人在分析Java排序算法之希尔排序问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析Java排序算法之希尔排序”的疑惑有所帮助!接下来...
    99+
    2023-06-25
  • C#算法之冒泡排序、插入排序、选择排序
    冒泡排序法 是数组等线性排列的数字从大到小或从小到大排序。 以从小到大排序为例。 数据 11, 35, 39, 30, 7, 36, 22, 13, 1, 38, 26, 18, 1...
    99+
    2024-04-02
  • 好程序员Python培训分享Python程序员面试技巧
      好程序员Python培训分享Python程序员面试技巧,往年的这个时候,“金三银四”的招聘热潮已经扑面而至。今年,因为疫情的影响,各大公司的社招可能跟“2002的第一场雪”一样,比以往时候来得更晚一些。当然,对于计划在年后找工作或者跳槽...
    99+
    2023-06-01
  • Java排序算法之选择排序
    目录一、选择排序二、代码实现三、测试一、选择排序 选择排序就是在每一次遍历过程中将数组中值最小的排到当前的第一位。 总共需要(数组长度-1)次遍历,在每次遍历中假定第一位索引的值为最...
    99+
    2024-04-02
  • java排序算法之冒泡排序
    本文实例为大家分享了java排序算法之冒泡排序的具体代码,供大家参考,具体内容如下 冒泡排序 冒泡排序无疑是最为出名的排序算法之一,从序列的一端开始往另一端冒泡(你可以从左往右冒泡,...
    99+
    2024-04-02
  • java 排序算法之归并排序
    目录简单介绍基本思想思路分析代码实现对代码的一些改进大数据量耗时测试复杂度简单介绍 归并排序(merge sort)是利用 归并 的思想实现的排序方法,该算法采用经典的分治(divi...
    99+
    2024-04-02
  • java 排序算法之快速排序
    目录简单介绍基本思想思路分析代码实现推导实现完整实现大数据量耗时测试性能分析简单介绍 快速排序(Quicksort) 是对 冒泡排序的一种改进。 基本思想 快速排序算法通过多次比较和...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作