Java 十大排序算法之计数排序刨析

 更新时间:2021年11月24日 09:17:37   作者:龍弟-idea  
计数排序是一个非基于比较的排序算法,该算法于1954年由 Harold H. Seward 提出。它的优势在于在对一定范围内的整数排序时,它的复杂度为Ο(n+k)(其中k是整数的范围),快于任何比较排序算法

计数排序是非比较的排序算法,用辅助数组对数组中出现的数字计数,元素转下标,下标转元素

计数排序优缺点

优点:快

缺点:数据范围很大,比较稀疏,会导致辅助空间很大,造成空间的浪费

使用范围:数据较为密集或范围较小时适用。

思路

1.找出最大元素max

2.初始化一个max+1的数组

3.将每个元素的计数存储在数组中各自的索引处

4.存储计数数组元素的累积和

5.数组中找到原始数组的每个元素的索引

计数排序代码实现

public class CountingSort {
    private static int[] countingSort(int[] arr) {
        //1、求取最大值和最小值,计算中间数组的长度:中间数组是用来记录原始数据中每个值出现的频率
        int min = arr[0], max = arr[0];
        for (int i : arr) {
            if (i > max) {
                max = i;
            }
            if (i < min) {
                min = i;
            }
        }
 
        //2、有了最大值和最小值能够确定中间数组的长度
        //例如存储 5-0+1=6
        int[] countArray = new int[max - min + 1];
 
        //3、循环遍历旧数组计数排序: 就是统计原始数组值出现的频率到中间数组B中
        for (int i : arr) {
            countArray[i - min] += 1; //数的位置上+1
        }
 
        //4、统计数组做变形,后边的元素等于前面的元素之和
        for (int i = 1; i < countArray.length; i++) {
            countArray[i] += countArray[i - 1];
        }
 
        //5、倒序遍历原始数组,从统计数组中找到正确的位置,输出到结果数组
        int[] resultArray = new int[arr.length];
        for (int i = arr.length - 1; i >= 0; i--) {
            //给resultArray的当前位置赋值
            resultArray[countArray[arr[i] - min] - 1] = arr[i];
            //给countArray的位置的值--
            countArray[arr[i] - min]--;
        }
        return resultArray;
    }
 
    public static void main(String[] args) {
        int[] arr = {1,28,3,21,11,7,6,18};
        int[] sortedArr = countingSort(arr);
        System.out.println(Arrays.toString(sortedArr));
    }
}

时间复杂度:O(n+k)

到此这篇关于Java 十大排序算法之计数排序刨析的文章就介绍到这了,更多相关Java 计数排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • restTemplate超时处理的策略方案

    restTemplate超时处理的策略方案

    这篇文章主要为大家介绍了restTemplate超时处理的策略方案,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Java线程间共享实现方法详解

    Java线程间共享实现方法详解

    这篇文章主要介绍了Java线程间共享实现方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Java异常基础知识解析

    Java异常基础知识解析

    这篇文章主要介绍了Java异常基础知识解析,具有一定借鉴价值,需要的朋友可以资参考下。
    2017-12-12
  • SpringMVC接收java.util.Date类型数据的2种方式小结

    SpringMVC接收java.util.Date类型数据的2种方式小结

    这篇文章主要介绍了使用SpringMVC接收java.util.Date类型数据的2种方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • @insert mybatis踩坑记录,实体接收前端传递的参数

    @insert mybatis踩坑记录,实体接收前端传递的参数

    这篇文章主要介绍了@insert mybatis踩坑记录,实体接收前端传递的参数问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • springboot+redis 实现分布式限流令牌桶的示例代码

    springboot+redis 实现分布式限流令牌桶的示例代码

    这篇文章主要介绍了springboot+redis 实现分布式限流令牌桶 ,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • SpringBoot集成WebSocket长连接实际应用详解

    SpringBoot集成WebSocket长连接实际应用详解

    这篇文章主要介绍了SpringBoot集成WebSocket长连接实际应用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • 浅析java贪心算法

    浅析java贪心算法

    这篇文章简单主要介绍了java贪心算法,包含贪心算法的基本思路,性质,以及实现示例,有需要的小伙伴参考下
    2015-02-02
  • SpringBoot @Autowired注解注入规则介绍

    SpringBoot @Autowired注解注入规则介绍

    这篇文章主要介绍了SpringBoot @Autowired注解注入规则介绍,具有很好的参考价值,希望对大家有所帮助。
    2021-11-11
  • Java读取Properties文件几种方法总结

    Java读取Properties文件几种方法总结

    这篇文章主要介绍了 Java读取Properties文件几种方法总结的相关资料,需要的朋友可以参考下
    2017-04-04

最新评论