栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java插入排序

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java插入排序

public class code_select {

    // 插入排序
    public static  void  insertSort(int [] arr){
        if(arr == null || arr.length < 2){
            return;
        }
        
        int N = arr.length;
        for (int end = 1; end < N; end++) {
            int newNumIndex =  end;
            while (newNumIndex - 1 >= 0 && arr[newNumIndex - 1] > arr[newNumIndex]){
                swap(arr, newNumIndex-1, newNumIndex);
                newNumIndex--;
            }

        }
    }

    public static  void  insertSort2(int [] arr){
        // 边界值检查
        if(arr == null ||  arr.length < 2){
            return;
        }
        int N = arr.length;
        
        for (int end = 1 ; end < N; end ++){
            for (int pre = end - 1 ; pre >= 0 && arr[pre] > arr[pre + 1]; pre -- ){
                swap(arr, pre, pre + 1);
            }
        }

    }


    public static  void  swap(int[] arr, int i , int j){
        int temp = arr[j];
        arr[j] = arr[i];
        arr[i] = temp;
    }

    public static  void  printArray(int [] arr){
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }


    public static void main(String[] args) {
        int[] arr = {7, 1, 2, 3, 5, 8};
        printArray(arr);
        insertSort(arr);
        printArray(arr);

    }

}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/735407.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号