zoukankan      html  css  js  c++  java
  • 计数排序-非比较排序

      适用场景:量大但是范围小

    package com.example.sort.count;
    
    import java.util.Arrays;
    
    public class CountSort {
        public static void main(String[] args) {
            int[] arr = {2, 4, 2, 3, 7, 1, 1, 0, 0, 5, 6, 9, 8, 5, 7, 4, 0, 9};// 0-9之间的数字
            int[] result = sort(arr);
            System.out.println(Arrays.toString(result));
        }
    
        /**
         * 计数排序
         *
         * @param arr
         */
        private static int[] sort(int[] arr) {
            //创建临时存储数组
            int[] result = new int[arr.length];
            // 建立0-9容器
            int[] count = new int[10];
            // 如果出现容器对应下标的数出现就给位置的对应值 +1
            for (int i = 0; i < arr.length; i++) {
                count[arr[i]]++;
            }
            // 开始清空容器值,置入临时返回数组中
            for (int i = 0, j = 0; i < count.length; i++) {
                while (count[i]-- > 0) {
                    result[j++] = i;
                }
            }
            return result;
        }
    
        private static void swap(int[] arr, int i, int j) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
    
        private static void print(int[] arr) {
    
            for (int i : arr) {
                System.out.print(i + " ");
            }
        }
    }
    

      优化后

    package com.example.sort.count;
    
    import java.util.Arrays;
    
    public class CountSort {
        public static void main(String[] args) {
            int[] arr = {2, 4, 2, 3, 7, 1, 1, 0, 0, 5, 6, 9, 8, 5, 7, 4, 0, 9};// 0-9之间的数字
            int[] result = sort(arr);
            System.out.println(Arrays.toString(result));
        }
    
        /**
         * 计数排序
         *
         * @param arr
         */
        private static int[] sort(int[] arr) {
            //创建临时存储数组
            int[] result = new int[arr.length];
            // 建立0-9容器
            int[] count = new int[10];
            // 如果出现容器对应下标的数出现就给位置的对应值 +1
            for (int i = 0; i < arr.length; i++) {
                count[arr[i]]++;
            }
    //        // 开始清空容器值,置入临时返回数组中
    //        for (int i = 0, j = 0; i < count.length; i++) {
    //            while (count[i]-- > 0) {
    //                result[j++] = i;
    //            }
    //        }
            // 优化
            for (int i = 1; i < count.length; i++) {
                count[i] = count[i] + count[i - 1];
            }
            for (int i = arr.length-1;i>=0;i--){
                result[--count[arr[i]]] = arr[i];
            }
            return result;
        }
    
        private static void swap(int[] arr, int i, int j) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
    
        private static void print(int[] arr) {
    
            for (int i : arr) {
                System.out.print(i + " ");
            }
        }
    }
    

      

  • 相关阅读:
    localStorage cache
    webpack的学习过程
    npm install --save/--save-dev的区别
    .gitignore常见问题
    jQuery的优点与缺点
    JSONP是什么
    Node.js-Usage & Example
    【转】Swig Getting Started
    【转】使用Spring MVC统一异常处理实战
    C++-Qt【5】-QT的QString,char*,QByteArray转化以及中文乱码的问题
  • 原文地址:https://www.cnblogs.com/huan30/p/12849761.html
Copyright © 2011-2022 走看看