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

选择排序、冒泡排序、插入排序【十大经典排序算法】

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

选择排序、冒泡排序、插入排序【十大经典排序算法】

选择排序、冒泡排序、插入排序【十大经典排序算法】

利用对数器验证结果【选用Arrays.sort()系统提供的来】

1 选择排序【选最小】
//选择排序【每次选出一个最小的】
public static void selectSort(int[] arr){
    if(arr == null || arr.length < 2){
        return;
    }
    for (int i = 0; i < arr.length - 1; i++){
        int min = i;//假设i位置为最小值
        for (int j = i+1; j < arr.length; j++) {
            if(arr[j] < arr[min]){
                min = j;
            }
        }
        swap(arr, i, min);
    }
}
2 冒泡排序【选最大】
//冒泡排序[每次选出最大的]
public static void bubbleSort(int[] arr){
    if(arr == null || arr.length < 2){
        return;
    }
    for (int i = 0; i < arr.length - 1; ++i){
        for(int j = 0; j < arr.length - i - 1; ++j){
            if(arr[j] > arr[j+1]){
                swap(arr, j, j+1);
            }
        }
    }
}
3 插入排序【前面有序】
//插入排序[保证前面部分全部有序]
public static void insertSort(int[] arr){
    if(arr == null || arr.length < 2){
        return;
    }
    for(int i = 1; i < arr.length; ++i){ //保证[0, i]位置上有序
        for(int j = i - 1; j >= 0; j--){
            if(arr[j] > arr[j+1]){
                swap(arr, j, j+1);
            }
        }
    }
}
4 对数器 4.1 gernateRandomArr(int maxSize, int maxValue)

Math.random() -> [0,1) 所有的小数,等概率返回一个
Math.random() * N -> [0,N) 所有小数,等概率返回一个
(int)(Math.random() * N) -> [0,N-1] 所有的整数,等概率返回一个

arr[i] = (int)((Math.random()+1) * maxValue - Math.random() * maxValue);
【保证有正有负】

//构建随机数组
public static int[] generateRandomArr(int maxSize, int maxValue){
    // Math.random() -> [0,1) 所有的小数,等概率返回一个
    // Math.random() * N -> [0,N) 所有小数,等概率返回一个
    // (int)(Math.random() * N) -> [0,N-1] 所有的整数,等概率返回一个
    int[] arr = new int[(int)(Math.random() * (maxSize + 1))];
    for (int i = 0; i < arr.length; i++) {
        arr[i] = (int)((Math.random()+1) * maxValue - Math.random() * maxValue);
    }
    return arr;
}
4.2 copy(int[] arr)
//复制数组
public static int[] copy(int[] arr){
    if(arr == null){
        return null;
    }
    int[] res = new int[arr.length];
    int i = 0;
    for (int num : arr) {
        res[i++] = num;
    }
    return res;
}
4.3 isEq
//判断数组是否相等
public static boolean isEq(int[] arr1, int[] arr2){
	 if((arr1 == null && arr2 != null) || (arr1 != null && arr2 == null)){
	     return false;
	 }
	 if(arr1 == null && arr2 == null){
	     return true;
	 }
	 if(arr1.length != arr2.length){
	     return false;
	 }
	 for(int i = 0; i < arr1.length; ++i){
	     if(arr1[i] != arr2[i]){
	         return false;
	     }
	 }
	 return true;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/1036424.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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