美文网首页
一遍文章搞定插入排序-java版

一遍文章搞定插入排序-java版

作者: shengjk1 | 来源:发表于2020-04-13 22:20 被阅读0次
  1. 插入排序

1.1 插入排序的基本介绍

插入排序属于内排,就是以插入的方式来达到排序的目的

1.2 插入排序思想

将待排序的数组看成一个有序列表和一个无序列表。刚开始时有序列表只有一个元素 arr[0],无序列表有n-2 的数据 arr[1] ~ arr[n-1]。排序开始,每次从无序列表中取出第一个元素,找到相应的位置,并将其按照插入有序列表中。

1.3 插入排序的时间复杂度和空间复杂度等

算法名称 平均时间复杂度 最好情况 最坏情况 空间复杂度 稳定性
插入排序 O(n^2) O(n) O(n^2) O(1) 稳定
  1. 代码演示

/**
 * @author shengjk1
 * @date 2020/4/9
 */
public class InsertSort {
    public static void main(String[] args) {
        int[] arr = new int[8];
        for (int i = 0; i < 8; i++) {
            arr[i] = (int) (Math.random() * 80000000);
        }

        for (int i = 1; i < arr.length; i++) {
            int insertIndex = i;
            int insertValue = arr[insertIndex];
            
            //找到相应的位置
            while (insertIndex - 1 >= 0 && arr[insertIndex - 1] > insertValue) {
                arr[insertIndex] = arr[insertIndex - 1];
                insertIndex--;
            }
            //并将其按照插入有序列表中
            arr[insertIndex] = insertValue;
            System.out.printf("第%d次遍历 insertIndex %d arr:%s", i, insertIndex, Arrays.toString(arr));
            System.out.println();
        }
    }
}

相关文章

  • 一遍文章搞定插入排序-java版

    插入排序 1.1 插入排序的基本介绍 插入排序属于内排,就是以插入的方式来达到排序的目的 1.2 插入排序思想 将...

  • 一遍文章搞定插值查找-Java版

    插值查找 与二分查找基本相似,就是 mid 的值不一样 代码演示 适用场景 1.对于数据量较大,关键字分布均匀的查...

  • Java 实现插入排序

    本文介绍插入排序原理及 Java 语言实现。 目录 插入排序原理 代码实现版本一版本二单元测试 插入排序原理 从第...

  • c++day09

    插入排序基础版(后插1) 插入排序基础版(后插2) 改进 插入排序基础版(前插) 字符数组 ASCII 的 A =...

  • java 实现排序算法之「插入排序」

    java 实现排序算法系列 这是 Java 实现排序算法的第三篇文章——插入排序算法。插入排序可以说成是「一类」简...

  • 插入排序 --- Java版

    算法思路 插入排序就是每一步都将一个待排数据按其大小插入到已经排序的数据中的适当位置,直到全部插入完毕。 非常类似...

  • 熟记代码片段

    1.转自 一遍记住Java常用的八种排序算法与代码实现 直接插入排序:

  • java快速学习排序---插入排序

    1.java实现插入排序 (1)、图解插入排序 (2)、插入排序的思想 (3)、插入排序的代码实现

  • 程序兵法:插入排序算法 Java 源版

    《程序兵法: Java 源码的插入排序算法 (二)》 文章工程: JDK 1.8 工程名:algorithm-co...

  • 程序兵法:插入排序算法 Java 源版

    《程序兵法: Java 源码的插入排序算法 (二)》 文章工程: JDK 1.8 工程名:algorithm-co...

网友评论

      本文标题:一遍文章搞定插入排序-java版

      本文链接:https://www.haomeiwen.com/subject/vlbomhtx.html