• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
gaohuan30
博客园    首页    新随笔    联系   管理    订阅  订阅
计数排序-非比较排序

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

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 + " ");
        }
    }
}

  

posted on 2020-05-08 12:20  gaohuan30  阅读(186)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3