三大进阶排序算法

计数排序

找到最大值,然后申请一个最大值+1大小的count数组。

使用count数组来对出现过的数字进行计数统计。此时count数组的索引就是排序好的数字。

遍历count数组,根据count数组的索引和出现的次数生成排序后的结果放入另一个数组中。

复制代码
public static void main(String[] args) {
    int[] a = {3, 9, 7, 2, 5, 8, 1, 4};
    System.out.println(Arrays.toString(a));
    sort(a);
    System.out.println(Arrays.toString(a));
}


private static void sort(int[] a){
    int max = Integer.MIN_VALUE;
    for (int i = 0; i < a.length; i++) {
        if(a[i] > max){
            max = a[i];
        }
    }
    int[] count = new int[max + 1];
    for (int i = 0; i < a.length; i++) {
        count[a[i]]++;
    }
    int i = 0;
    int j = 0;
    while(i < a.length){
        if(count[j] == 0){
            j++;
        }
        int t = count[j];
        while(t > 0 && i < a.length){
            a[i] = j;
            t--;
            i++;
        }
        j++;
    }
}

桶排序

使用动态数组申请一个桶。

遍历原数组,通过除法找到动态数组索引放入数据。

对桶内元素排序,结果放回原数组中。

复制代码
public static void main(String[] args) {
    int[] a = {20, 18, 66, 25, 67, 30};
    System.out.println(Arrays.toString(a));
    sort(a,10);
    System.out.println(Arrays.toString(a));
}


private static void sort(int[] a,int size){
    List<List<Integer>> buckets = new ArrayList<>();
    List<Integer> bucket = null;
    for (int i = 0; i < size; i++) {
        bucket = new ArrayList<>();
        buckets.add(bucket);
    }
    for (int i : a) {
        List<Integer> integerList = buckets.get(i / 10);
        integerList.add(i);
    }
    int k = 0;
    for (List<Integer> integerList : buckets) {
        integerList.sort(Integer::compareTo);
        for (Integer i : integerList) {
            a[k++] = i;
        }
    }
}

基数排序

思想跟桶排序差不多,只不过是从最低位开始排序,通过循环排到最高位。

复制代码
 public static void radixSort(String[] a, int length) {
        ArrayList<String>[] buckets = new ArrayList[128];
        for (int i = 0; i < buckets.length; i++) {
            buckets[i] = new ArrayList<>();
        }
        for (int i = length - 1; i >= 0 ; i--) {
            for (String s : a) {
                buckets[s.charAt(i) - "0"].add(s);
            }
            int k = 0;
            for (ArrayList<String> bucket : buckets) {
                for (String s : bucket) {
                    a[k++] = s;
                }
                bucket.clear();
            }
        }
    }


    public static void main(String[] args) {
        String[] phoneNumbers = new String[10];
        phoneNumbers[0] = "138";
        phoneNumbers[1] = "139";
        phoneNumbers[2] = "136";
        phoneNumbers[3] = "137";
        phoneNumbers[4] = "135";
        phoneNumbers[5] = "134";
        phoneNumbers[6] = "150";
        phoneNumbers[7] = "151";
        phoneNumbers[8] = "152";
        phoneNumbers[9] = "157";
        RadixSort.radixSort(phoneNumbers, 3);
        for (String phoneNumber : phoneNumbers) {
            System.out.println(phoneNumber);
        }
    }
相关推荐
是小崔啊9 分钟前
开源轮子 - EasyExcel01(核心api)
java·开发语言·开源·excel·阿里巴巴
ALISHENGYA15 分钟前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
chengooooooo17 分钟前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
黄公子学安全18 分钟前
Java的基础概念(一)
java·开发语言·python
liwulin050619 分钟前
【JAVA】Tesseract-OCR截图屏幕指定区域识别0.4.2
java·开发语言·ocr
jackiendsc24 分钟前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法
Yuan_o_24 分钟前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
Oneforlove_twoforjob28 分钟前
【Java基础面试题027】Java的StringBuilder是怎么实现的?
java·开发语言
数据小小爬虫1 小时前
利用Java爬虫获取苏宁易购商品详情
java·开发语言·爬虫
小汤猿人类1 小时前
nacos-服务发现注册
java·开发语言·服务发现