Java 十大排序算法之计数排序刨析
作者:龍弟-idea 发布时间:2023-11-28 19:21:26
标签:Java,计数排序,排序算法
计数排序是非比较的排序算法,用辅助数组对数组中出现的数字计数,元素转下标,下标转元素
计数排序优缺点
优点:快
缺点:数据范围很大,比较稀疏,会导致辅助空间很大,造成空间的浪费
使用范围:数据较为密集或范围较小时适用。
思路
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)
来源:https://blog.csdn.net/weixin_48838340/article/details/121451443


猜你喜欢
- 方法重载概述方法重载指同一个类中定义的多个方法之间的关系,满足下列条件的多个方法互相构成重载* 多个方法在同一个类中* 多个放方法具有相同方
- 程序设计成为简单的服务端和客户端之间的通信, 但通过一些方法可以将这两者进行统一起来, 让服务端也成为客户端, 让客户端也成为服务端, 使它
- 在做商城的项目中,有这么个需求,就是一个产品下有两个价格,一个是市场价,一个是销售价,这时要把市场价添加个删除线;刚开始遇到这个时,在网上找
- 本文为大家分享了Android APP编写的简单答题器,此答题器可以通过Next按钮选择下一题,新写题目的类Question,有两个成员变量
- 我们在设计layout的时候,使用Split视图,就是左侧是代码,右侧是设计图,但是我们忽视了最上方的工具栏,这里才是真正的宝藏。下面教大家
- 判断一个数是不是回文数示例,回文数就是原数与其倒置后的数相等,如:123321,到之后仍为123321,即为回文数题目:一个5位数,判断它是
- 经过上一篇的介绍,相信小伙伴们已经按奈不住内心对springboot的向往,本篇我将继续向小伙伴介绍springboot配置文件的配置,已经
- 自C#1.0版本以来,我们要定义一个不可变数据类型的基本做法就是:先声明字段为readonly,再声明只包含get访问器的属性。例子如下:1
- Java RandomAccessFile 指定位置实现文件读取与写入RandomAccessFile是属于随机读取类,是可以对文件本身的内
- 你以前听到的谈论关于Java8的所有都是围绕lambda表达式. 但它仅仅是Java8的一部分. Java 8 有许多新特性—一些强大的新类
- 本文实例讲述了Android4.4电池低电量告警提示原理与实现方法。分享给大家供大家参考,具体如下:之前版本的电池电量低是通过发送 inte
- 本文实例讲述了C#判断访问来源是否为搜索引擎链接的方法。分享给大家供大家参考。具体分析如下:这段代码通过获取UrlReferrer判断访客是
- 目录1.引用Nuget包 ServiceStack.Redis2. string 类型的使用作
- Spring Security是一款基于Spring框架的认证和授权框架,提供了一系列控制访问和保护应用程序的功能,同时也支持基于角色和权限
- 前言我们在项目的开发中,难免会遇到各种可预知的、不可预知的异常需要处理。每个过程都单独处理异常,系统的代码耦合度高,工作量大且不好统一,维护
- 本文详述了android抽奖程序的实现方法,程序为一个抽奖大转盘代码,里面定义了很多图形方法和动画。实现主要功能的SlyderView.ja
- 简介:接上文实现对FTP的传送文件,此文和上文可以说是如出一辙,不过此文是通过cmd进行建立连接的,建立连接后也是通过以下几个步骤实现操作。
- 一、问题描述平时我们在完成某些数据的入库后,发布了一个事件,此时使用的是@EventListener,然后在这个事件中,又去对刚才入库的数据
- 需求:当时间在凌晨0点至0点5分之间程序不执行。也就是实现判断当前时间点是否在
- 通过Class对象获取对象的方式是通过class.newInstance()方式获取,通过调用默认构造参数实例化一个对象。/** * Cre