zoukankan      html  css  js  c++  java
  • 计数排序and基数排序

    1 计数排序,稳定    复杂度o(k + n)

        public static int[] countingSort(int[] nums) {
            int n = nums.length;
            int k = 0;
            for (int i = 0; i < n; i++) {
                k = Math.max(k, nums[i]);
            }
            int[] count = new int[k + 1];
            int[] res = new int[n];
            for (int i = 0; i < n; i++) {
                count[nums[i]]++;
            }
            for (int i = 1; i <= k; i++) {
                count[i] += count[i - 1];
            }
            for (int i = n - 1; i >= 0; i--) {
                res[--count[nums[i]]] = nums[i];
            }
            return res;
        }
    View Code

    2 基数排序 需要稳定排序  有n个d位数,每一位有k个取值,复杂度为d(n + k)

        public static int[] radixSort(int[] nums) {
            int max = 0;
            int n = nums.length;
            for (int i = 0; i < nums.length; i++) {
                max = Math.max(max, nums[i]);
            }
            int exp = 1;
            int[] cur = new int[n];
            while (max / exp > 0) {
                int[] count = new int[10];            
                for (int i = 0; i < n; i++) {
                    count[(nums[i] / exp) % 10]++;
                }
                for (int i = 1; i < 10; i++) {
                    count[i] += count[i - 1];
                }
                for (int i = n - 1; i >= 0; i--) {
                    cur[--count[(nums[i] / exp) % 10]] = nums[i];
                }
                for (int i = 0; i < n; i++) {
                    nums[i] = cur[i];
                }
                exp *= 10;
            }
            return nums;
        }
    View Code

    3 桶排序

  • 相关阅读:
    CSS
    javaScript高级:BOM和DOM
    Layui在弹出层实现轮播图效果
    SQL
    jQuery基础
    清除重复值:distinct
    tomcat的server.xml中进行配置来实现访问本地电脑的图片
    jQuery高级
    javascript基础:ECMAScript
    设计模式六大原则【设计模式学习开篇】
  • 原文地址:https://www.cnblogs.com/whesuanfa/p/7534892.html
Copyright © 2011-2022 走看看