(排序9)非比较排序之计数排序

news2024/9/24 5:26:42

非比较排序之计数排序

  1. 之前讲的七种排序方法的话,都是比较排序;除此之外还有三种非比胶排序:计数排序,基数排序,桶排序。后面两个实际应用没啥,没啥价值。非比较排序的话,他的条件都比较苛刻,就是说他一般不适用于常规的场景,适用于特殊的场景。
  2. 计数排序其实就是基于哈希,只不过就是现在还没学过而已,计数排序就是说不借助于这么去比较大小。
  3. 计数排序的话就是说去统计每个数据出现的次数。比如说你已经知道这个数组总的数据范围是在0~9,然后他就是先给每一个数据建立一个坑位0.1.2.3.4.5.6.7.8.9(其实就是可以新创建一个数组,然后注意:这个新数组的下标就对应到数据数值),这些专属的坑位就是用来统计这个数据它出现的次数,最先开始初始化新数组为0。
  4. 然后就是去遍历原先的数组,然后就会得到一个又一个的原先数组当中的数值,然后再把这些得到的数值对应到新数组的下标,对新数组下标所指向的那个数据(最开始初始化为0)进行++。
  5. 然后接下来就可以进行排序,对数组直接怼上去覆盖。首先遍历这个计数新数组,比如说对那个新数组从左到右进行遍历的话,1出现了2次,那么就在原数组给他从头开始覆盖两个2;然后3出现了1次,再在原数组接着继续去覆盖一个3…

从绝对映射优化到相对映射

  1. 当前方式还不够好,比如说现在我需要排序的数据是100,105,105,101,102,100,109,100。那我如果采用绝对映射的话,我要开110个元素的数组,然后开了那么大结果映射出来就只单单映射在最尾巴那部分,浪费空间啊,前面空间白开了啊。因此采用绝对映射的话是不妥的
  2. 相对映射:首先必须得去找到原数组当中的最大值与最小值,然后把两者的差range给他算出来。
  3. 然后我新开计数数组的时候,我开一个range+1大的就OK了。此时不是绝对映射,映射关系如下:
    在这里插入图片描述
  4. 总而言之,计数新数组下标与原先数组数值之间是属于映射关系: 新数组下标 + min = 原先数组数值
  5. 如果说是在绝对映射的情况之下,那有负数是肯定不可以的,但如果是像上面那样进行相对映射的话,是OK了的。
void CountSort(int* arr, int n)
{
	int min = arr[0];
	int max = arr[0];
	for (int i = 0; i < n; i++)
	{
		if (arr[i] < min)
		{
			min = arr[i];
		}
		if (arr[i] > max)
		{
			max = arr[i];
		}
	}
	int range = max - min;
	int* countarr = (int*)malloc(sizeof(int) * (range + 1));
	if (countarr == NULL)
	{
		perror("malloc failed");
		return;
	}
	memset(countarr, 0, sizeof(int) * (range + 1));
	for (int i = 0; i < n; i++)
	{
		countarr[arr[i] - min]++;
	}
	int j = 0;
	for (int i = 0; i <= range; i++)
	{
		while (countarr[i]--)
		{
			arr[j++] = i + min;
		}
	}
	free(countarr);
}
  1. 但这种方法有时候也不太行的,当碰到另外一种场景,相对映射他就又挂了。当你数字范围分散的时候又裂开了。
  2. 因此计数排序适合范围集中且范围不大的整形数组排序。不适合非整形(如浮点,字符串,因为这时候你无法对应映射到新的计数数组的下标去了,只有整型可以)与范围分散的场景。

时间复杂度

  1. 首先在这种排序的话,它对原数组首先得遍历一遍去找到最大值,最小值,这就是O(N)。
  2. 然后还得再去遍历一遍这个原先的数组,对于数组当中的每一个数值通过映射关系找到他在新数组当中对应的下标,然后把这个下标对应位置的新数组数值给他加1。这也是O(N)
  3. 然后还得去遍历一遍新数组,与此同时,从开头开始要对原先数组进行覆盖操作。当新数组遍历完成之后,此时原先数组已经焕然一新,变成排序完成好之后了。这个过程需要O(range+1),这个range就是max-min.
  4. 所以总共的时间复杂度就是O(N和range的较大值)

在这里插入图片描述
6.
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/431020.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HTTP 和 HTTPS(请求响应报文格式 + 请求方法 + 响应状态码 + HTTPS 加密流程 + Cookie 和 Session)

文章目录1. HTTP 是什么2. HTTP 请求报文和响应报文的格式1&#xff09;请求报文格式2&#xff09;响应报文格式3&#xff09;报文中空行的作用3. HTTP 的长连接和短连接4. URL1&#xff09;在浏览器中输入 www.baidu.com 后执行的全部过程5. HTTP 常用的请求方法6. GET 和 POS…

自媒体都在用的5个素材网站,视频、音效、图片全部免费下载~

推荐几个自媒体必备的素材库&#xff0c;免费可商用&#xff0c;建议收藏&#xff01; 1、菜鸟图库 视频素材下载_mp4视频大全 - 菜鸟图库 国内超大的素材库&#xff0c;在这里你可以找到设计、办公、图片、视频、音频等各种素材。视频素材就有上千个&#xff0c;全部都很高清…

后端应用架构

微服务架构划分 ⚠️ 生产环境实际部署中&#xff0c;基础能力、公共基础能力将分别在国内、美国集群部署。在没有引入数据同步的场景下&#xff0c;数据是隔离的。 接入层&#xff08;交互层&#xff09; 接入层主要完成协议转换、熔断限流、统一鉴权等能力&#xff0c;起到保…

Linux网络服务之ftp

目录 一.ftp的相关知识1.1 ftp的简介1.2 ftp的数据连接模式 二.svftpd的安装和配置2.1 svftpd安装3.2 设置本地用户验证访问ftp3.2.1 设置本地用户可以访问ftp&#xff0c;禁止匿名用户登录3.2.2 对本地用户访问切换目录进行限制 3.3 黑名单和白名单的使用3.3.1 黑名单的使用3.…

ASEMI代理AD9959BCPZ原装ADI车规级AD9959BCPZ

编辑&#xff1a;ll ASEMI代理AD9959BCPZ原装ADI车规级AD9959BCPZ 型号&#xff1a;AD9959BCPZ 品牌&#xff1a;ADI /亚德诺 封装&#xff1a;LFCSP-56 批号&#xff1a;2023 安装类型&#xff1a;表面贴装型 引脚数量&#xff1a;56 类型&#xff1a;车规级芯片 工作…

【18图详解3种典型网络拓扑:如何设计一个网络?】

前言 在网络设计的时候&#xff0c;网络架构师需要根据组网的规模设计不同的组网架构&#xff0c;今天介绍3种典型网络架构。 小型组网架构 1、网络拓扑 终端用户接入到交换机&#xff0c;交换机直连防火墙构成的简单网络&#xff0c;防火墙连接internet&#xff0c;对内网的用…

Java并发控制 学习笔记1

一、并发控制的方法 1、悲观锁&#xff1a;常用的互斥锁都属于悲观锁&#xff0c;一个线程访问共享资源时其他线程不能访问。 2、乐观锁&#xff1a;允许同时访问共享数据&#xff0c;只有在提交时利用如版本号检查是否有冲突&#xff0c;应用github。 3、什么时候用乐观锁、什…

开发必备:EsayCode使用以及Oracle自定义模板

前言 写前先问一句&#xff0c;不会还有人在手动写这些基础的sql语句吧&#xff1f;&#xff01; 最近在做Oracle的项目&#xff0c;手写mapper和entity文件真是写到手软&#xff0c;以前MySQL都是找的线上自动生成的&#xff0c;现在也不行了。 找了很长时间&#xff0c;也…

【Python】tkinter的简单使用(Tk对象、三大布局、变量、事件)

本文目录1.tkinter2.Tk对象3.三大布局3.1 pack布局3.2 grid布局3.3 place布局4.变量5.事件1.tkinter tkinter是Tcl/Tk GUI工具包&#xff08;即使用Tcl语言开发Tk图形库&#xff09;的标准Python接口&#xff0c;支持在Windows、macOS、Linux多平台运行。 tkinter是Python自带…

DPDK入门(环境搭建以及小demo)

文章目录零、从0开始配置dpdk环境的虚拟机一、dpdk的编译usertool/dpdk-setup.sh二、dpdk需要什么配置来支持1.多队列网卡2.巨页三、解析接收网络数据的过程经历了什么1.物理网卡2.NIC3.内核协议栈4.标准接口层Posix API5. 应用层上述过程发生的拷贝四、DPDK介绍基于上述接收网…

Github采用Http Push失败

Github采用Http Push失败 Github的密码凭证从2021年起开始就不能用了&#xff0c;现在采用http去push代码时候提示输入的密码要换成令牌&#xff08;token&#xff09;才可以。 如何在Github上生成自己的令牌呢&#xff1f; &#xff08;1&#xff09;简单来说就是将原来输入…

Linux搭建GitLab私有仓库,并内网穿透实现公网访问

文章目录前言1. 下载Gitlab2. 安装Gitlab3. 启动Gitlab4. 安装cpolar5. 创建隧道配置访问地址6. 固定GitLab访问地址6.1 保留二级子域名6.2 配置二级子域名7. 测试访问二级子域名前言 GitLab 是一个用于仓库管理系统的开源项目&#xff0c;使用Git作为代码管理工具&#xff0c…

游戏运营专员的职责有哪些?提高游戏收入的关键是什么?

游戏运营是将一款游戏平台推入市场&#xff0c;通过对平台的运作&#xff0c;使用户从接触、认识、再到了解实际线上的一种操作、最终成为这款游戏平台的忠实玩家的这一过程。同时通过一系列的营销手段达到提高线上人数&#xff0c;刺激消费增长利润的目的。 游戏运营专员的职…

4.3 协方差及相关系数、矩

学习目标&#xff1a; 我正在学习协方差、相关系数和矩&#xff0c;我会采取以下措施&#xff1a; 理解基本概念&#xff1a;首先&#xff0c;我会努力理解协方差、相关系数和矩的基本概念。我会查阅参考资料&#xff0c;例如课本或在线教程&#xff0c;以便深入了解这些概念…

Unity设计模式—子类沙盒

Unity设计模式—子类沙盒 一个基类定义了一个抽象的沙河方法和一些预定义的操作集合。通过将它们设置为受保护的状态已确定它们仅供子类使用。每个派生的沙盒子类根据父类提供的操作来实现沙盒操作。 子类沙盒的名字比较生僻&#xff0c;其实内容非常常见&#xff0c;平常用的很…

警惕,3月20日WOS目录更新,50本SCI/SSCI被剔除,这个出版社多达18本

2023年3月SCI、SSCI期刊目录更新 2023年3月20日&#xff0c;Web of Science核心期刊目录再次更新&#xff01;此次2023年3月SCIE & SSCI期刊目录更新&#xff0c;与上次更新&#xff08;2023年2月&#xff09;相比&#xff0c;共有50本期刊被剔除出SCIE & SSCI期刊目录…

香橙派4LTS和树莓派4B构建K8S集群实践之一:K8S安装

目录 1. 说明 1.1 软硬件环境 1.2 设计目标 2 实现 2.1 准备工作 - 香橙派 (k8s-master-1) - 树莓派 (k8s-node-1) - 两派都要干的事 2.2 containerd 安装与设置 2.3 安装 3 遇到的问题 3.1 k8s-master-1 3.2 k8s-node-1 4 相关命令 5 Tips 6 参考 1. 说明 …

【论文笔记】Deformable Convolutional Networks

1.介绍 1.1. 提出DCN的原因 卷积神经网络&#xff08;CNNs&#xff09;由于其固定几何结构局限了模型几何变换。 1.2.本文核心贡献&#xff1a;提出了两种新模块 deformable convolution 和 deformable RoI pooling 第一种是可变形卷积。它将2D偏移添加到标准卷积中的规则网…

【点云概述】什么是点云、来源、种类、特点、处理?

文章目录 一、什么是点云二、点云的来源三、点云的种类四、点云的特点五、点云的处理一、什么是点云 点云(point cloud)是空间中点的数据集,可以表示三维形状或对象,通常由三维扫描仪获取。点云中每个点的位置都由一组笛卡尔坐标 ( X , Y , Z ) (X, Y, Z) (X,Y,Z)描述,有…

【C++】4. 重载函数

文章目录 前言一、函数重载1.1 重载的条件1.2 函数名修饰 前言 自然语言中&#xff0c;一个词可以有多重含义&#xff0c;人们可以通过上下文来判断该词真实的含义&#xff0c;即该词被重载了。比如&#xff1a;以前有一个笑话&#xff0c;国有两个体育项目大家根本不用看&…