插入排序(Java)

复制代码
所谓插入排序法,就是检查第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)次。
因此,插入排序不适合对于数据量比较大的排序应用。
插入排序是稳定排序

算法实现:

java 复制代码
package com.feixiang.platform.stu.math.sorting;

/**
 * Created with IntelliJ IDEA.
 * Description: 插入排序
 * @PackageName com.feixiang.platform.stu.math.sorting
 * @Author: ldwtxwhspring
 * @Date: 2020-05-22 下午1:01
 * @Version: 1.0
 */
@SuppressWarnings("DuplicatedCode")
public class InsertSort {

    /**
     * 插入排序 升序
     * @param array [array]
     * @return void
     * @author dwli
     * @date 2020/5/22 下午5:30
     */
    public static void insertSort(int[] array){
        for(int i=1;i<array.length;i++){
            //定义插入数:
            int insertPointValues = array[i];

            //定义插入点:
            int insertPoint = i-1;

         while (insertPoint>=0 && insertPointValues<array[insertPoint]){
             //插入点值后移
            array[insertPoint+1] = array[insertPoint];
            //插入点标记前移
             insertPoint--;
         }
            //把插入值放到指定位置
            array[insertPoint+1] = insertPointValues;
        }
    }


    /**
     * 插入排序 降序
     * @param array [array]
     * @return void
     * @author dwli
     * @date 2020/5/22 下午5:40
     */
    public static void insertSortDesc(int[] array){
        for(int i=1;i<array.length;i++){
            //定义插入数:
            int insertPointValues = array[i];

            //定义插入点:
            int insertPoint = i-1;

            while (insertPoint>=0 && insertPointValues>array[insertPoint]){
                //插入点值后移
                array[insertPoint+1] = array[insertPoint];
                //插入点标记前移
                insertPoint--;
            }
            //把插入值放到指定位置
            array[insertPoint+1] = insertPointValues;
        }
    }

    /**
     * 自定义选择排序类型,
     * @param array
     * @param sortType 该值只能是布尔值,true 升序 false 降序
     * @return void
     * @author dwli
     * @date 2020/5/22 下午5:43
     */
    public static void insertSort(int[] array,boolean sortType){
        for(int i=1;i<array.length;i++){
            //定义插入数:
            int insertPointValues = array[i];

            //定义插入点:
            int insertPoint = i-1;

            while ((insertPoint >= 0) && (sortType? (insertPointValues > array[insertPoint]):(insertPointValues < array[insertPoint]))){
                //插入点值后移
                array[insertPoint+1] = array[insertPoint];
                //插入点标记前移
                insertPoint--;
            }
            //把插入值放到指定位置
            array[insertPoint+1] = insertPointValues;
        }
    }


    /**
     * 内部引用方法,实现数组转字符串,达到toString效果,类同重写tostring
     * */
    private static String arraytoString(int[] objects){
        StringBuilder sb = new StringBuilder();
        sb.append("[ ");
        for(Object o:objects){
            sb.append(String.valueOf(o)).append(",");
        }
        //删除多余追加的,
        sb.deleteCharAt(sb.length()-1);
        sb.append(" ]");
        return sb.toString();
    }

    public static void main(String[] args) {
        int[] array = new int[]{44,22,31,2,55,92,1,34,332,0,2,44};
        insertSort(array);
        System.out.println(arraytoString(array));
        insertSortDesc(array);
        System.out.println(arraytoString(array));
        int[] array1 = new int[]{44,22,31,2,55,92,1,34,332,0,2,44};
        insertSort(array1,true);
        System.out.println(arraytoString(array1));
        int[] array2 = new int[]{44,22,31,2,55,92,1,34,332,0,2,44,1};
        insertSort(array2,false);
        System.out.println(arraytoString(array2));
    }
}
相关推荐
风筝在晴天搁浅23 分钟前
字节高频题 小于n的最大数
算法
LabVIEW开发25 分钟前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
身如柳絮随风扬29 分钟前
多数据源切换实战:从业务场景到3种实现方案全解析
java·分布式·微服务
AI科技星30 分钟前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅32 分钟前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程1 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
Java小生不才1 小时前
Spring AI文生音
java·人工智能·spring
凯尔萨厮1 小时前
Springboot2.x+Thymeleaf项目创建
java
V搜xhliang02461 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
fish_xk1 小时前
map和set
java·开发语言