java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java插入排序

Java经典排序算法之插入排序代码实例

作者:恶魔青叶

这篇文章主要介绍了Java经典排序算法之插入排序代码实例,插入排序是一种最简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入,需要的朋友可以参考下

1.简介

插入排序是一种最简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

插入排序的时间复杂度是O(n^2) ,空间复杂度 是O(1)。 将第一个看成一个有序数列,将后面的数跟前面的数比较,大的就往后移

第一趟排序后:得到一个有序数列,其大小为2

第二趟排序后:得到一个有序数列,其大小为3

第三趟排序后:得到一个有序数列,其大小为4 …

每一趟插入排序,都可以将一个无序值插入一个有序数列,直至全部值有序

实现思路:

2.图解流程

在这里插入图片描述

3.代码实现

package com.znzz.insertSort;
import java.util.Arrays;
public class InsertSort {
    public static void main(String[] args) {
        inserrtSort(new int[]{6,2,0,2,4,7,9,10});
    }
    public static void inserrtSort(int[] arr) {
        int value;  //待插入元素
        int index;  //待插入元素的前一个元素的索引
        for (int i = 1; i < arr.length; i++) {
            //这里i=1,默认第一个元素是有序的,
            //循环条件是小于数组长度
            value = arr[i];
            index = i - 1;   //前一个元素
            while (index >= 0 && value < arr[index]){
                //需要保证index合法
                //每当前面的元素比待插入元素大,就向后移动
                arr[index + 1] = arr[index];
                index--;
        }
        //到这里表示退出循环,说明找到了待插入的位置,
        arr[index + 1] = value;
    }
        System.out.println(Arrays.toString(arr));
}
}

到此这篇关于Java经典排序算法之插入排序代码实例的文章就介绍到这了,更多相关Java插入排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文