非比较排序——计数排序

news2024/11/19 0:35:42

在这里插入图片描述

本章gitee代码:计数排序

文章目录

  • 🍇0. 前言
  • 🍈1. 思路
  • 🍉2. 代码实现
  • 🍊3. 优势与缺陷
  • 🍋4. 其他的非比较排序
    • 🫴桶排序
    • 🫴基数排序

🍇0. 前言

传统的排序方法通常需要逐个比较元素的大小,但非比较排序采用了一种不同的方法,即通过映射元素的值来统计相同元素的数量,然后将统计结果重新映射回原始序列,本章将介绍非比较排序中的计数排序。

如果对传统排序不熟悉的铁子可以查看此篇文章——数据结构——七大排序[源码+动图+性能测试]

🍈1. 思路

计数排序,开辟一个临时数组,初始值全部置0,然后遍历序列,将出现的元素对应下标进行统计,统计完毕之后,再出现归到原序列,形成有序序列。

然而,如果待排序序列中的值的范围较大,就会导致空间的浪费,例如,对于序列{100, 110, 120, 130…},我们需要为范围从0到99的元素都分配空间,这会造成大量的浪费。为了解决这个问题,我们可以采用相对映射的方式,先统计序列中的最大值和最小值,然后计算出值的范围。

count_s

🍉2. 代码实现

//小范围O(N+range)
void CountSort(int* a, int n)
{
	int max = a[0];
	int min = a[0];
	//找最大最小值
	for (int i = 0; i < n; i++)
	{
		if (a[i] > max)
			max = a[i];
		if (a[i] < min)
			min = a[i];
	}
	int range = max - min + 1;
	int* tmp = (int*)calloc(range, sizeof(int));
	if (tmp == NULL)
	{
		perror("malloc fail\n");
	}
	//相对映射
	for (int i = 0; i < n; i++)
	{
		int index = a[i] - min;
		tmp[index]++;
	}

	int j = 0;
	for (int i = 0; i < range; i++)
	{
		while (tmp[i]--)
			a[j++] = i + min;
	}
	free(tmp);
}

🍊3. 优势与缺陷

  • 优势: 计数排序在处理小范围数值的情况下性能强大,时间复杂度可达O(N),例如,对于考试成绩的统计范围在0~100之间的情况。
  • 缺陷: 计数排序的缺陷也很明显。当数值范围较大时,会导致大量空间的浪费。此外,计数排序只适用于整数排序,无法很好地处理浮点数或字符的排序需求。

🍋4. 其他的非比较排序

🫴桶排序

桶排序是一种非比较排序算法,它将元素分散到多个桶中,然后分别对每个桶中的元素进行排序,最后合并所有桶的结果以得到有序序列。桶排序适用于元素均匀分布在一个范围内的情况,时间复杂度可以达到O(N)。它的思想类似于计数排序,但可以处理浮点数等不适用于计数排序的数据类型。

🫴基数排序

基数排序是一种多次应用桶排序的排序算法,它按照元素的每一位进行排序,从最低位到最高位,直到所有位都排完为止。基数排序适用于对整数或字符串等有固定位数表示的数据进行排序,时间复杂度为O(kN),其中k为元素的最大位数。

Tips:
这两种排序在日常中并不常用,可以只做了解


主要还是得掌握传统的排序思想,非比较排序应用场景较少,具体还得看使用场景。
那么本次的分享就到这里咯,我们下期再见,如果还有下期的话。

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

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

相关文章

嵌入式Linux开发实操(十五):nand flash接口开发(2)

通用NAND驱动程序支持几乎所有基于NAND的芯片,并将它们连接到Linux内核的内存技术设备(MTD)子系统。这个接口走的是nand的并口,可以在shell的/dev中看到设备,比如/mtd0、/mtd0ro…,mtdblock0、mtdblock1… sysfs在设备层次结构中提供了几个视角。设备必须挂在某条总线bus…

Linux相关指令(下)

cat指令 查看目标文件的内容 常用选项&#xff1a; -b 对非空输出行编号 -n 对输出的所有行编号 -s 不输出多行空行 一个重要思想&#xff1a;linux下一切皆文件&#xff0c;如显示器文件&#xff0c;键盘文件 cat默认从键盘中读取数据再打印 退出可以ctrlc 输入重定向<…

CSP 202305-2 矩阵运算

样例输入 3 2 1 2 3 4 5 6 10 10 -20 -20 30 30 6 5 4 3 2 1 4 0 -5 样例输出 480 240 0 0 -2200 -1100 答题 注意数值范围用int已经不行了&#xff0c;必须要用long long 而且矩阵运算涉及到三层循环&#xff0c;可以利用cache机制减少取值时间&#xff0c;先将右矩阵转置…

Unity2D实现左右移动的敌人角色

文章目录 环境与角色创建敌人角色 敌人脚本检测前方是否有地面获取检测点检测地面 完整代码运行结果其他文章 环境与角色 创建敌人角色 简单起见&#xff0c;突出脚本的内容&#xff0c;我们就只创建一个圆形用来当做当前的敌人角色。 为分清左右&#xff0c;我们再为敌人角色…

时序预测 | MATLAB实现TCN-BiLSTM时间卷积双向长短期记忆神经网络时间序列预测

时序预测 | MATLAB实现TCN-BiLSTM时间卷积双向长短期记忆神经网络时间序列预测 目录 时序预测 | MATLAB实现TCN-BiLSTM时间卷积双向长短期记忆神经网络时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.MATLAB实现TCN-BiLSTM时间卷积双向长短期记忆神…

APACHE NIFI 删除组件报错

报错信息&#xff1a; Node 192.168.93.206:8443 is unable to fulfill this request due to: Controller Service 0e733621-f4ad-139e-8a25-8ad317eb6453 cannot be deleted because it is not disabled 步骤1&#xff1a;进入报错的流程里面&#xff0c;我的是到报错的Proce…

Arduino驱动LX1972传感器(光照传感器篇)

LX1972环境光(可见光)传感器,对可见光照度的反应特性与人眼的特性类似,可以模拟人对环境光线的强度的判断,从而方便做出与人友好互动的应用,可应用于照明控制、屏幕背光控制等。 1、传感器特性 传感器技术指标如下: 工作温度: -40~80C照度范围: 1 – 800Lux输出信号:…

【虹科干货】基本元件可靠性测试方案

01 内容摘要 本文介绍了一种基于可变形测试模块的电感和电阻测试系统&#xff0c;旨在解决传统手动测量方法存在的局限性和需求提升的问题。 该系统通过引入可变形测试模块、大规模矩阵和配套设备&#xff0c;实现了电感和电阻的大规模自动化测试。基于可变形测试模块的电感和…

MySQL——连接查询与子查询

一、连接查询 单表查询&#xff1a;在一张表当中查询数据&#xff0c;叫做单表查询。 连接查询&#xff0c;结合俩&#xff08;多&#xff09;张表&#xff0c;在俩张&#xff08;多&#xff09;表当中查询数据&#xff0c;在一张表当中查询一部分&#xff0c;在另一张表当中…

10.(Python数模)(预测模型二)LSTM回归网络(1→1)

LSTM回归网络&#xff08;1→1&#xff09; 长短期记忆网络 - 通常只称为“LSTM” - 是一种特殊的RNN&#xff0c;能够学习长期的规律。 它们是由Hochreiter&#xff06;Schmidhuber&#xff08;1997&#xff09;首先提出的&#xff0c;并且在后来的工作中被许多人精炼和推广。…

31 WEB漏洞-文件操作之文件包含漏洞全解

目录 文件包含漏洞原理检测类型利用修复 本地包含-无限制&#xff0c;有限制远程包含-无限制&#xff0c;有限制各种协议流玩法文章介绍读取文件源码用法执行php代码用法写入一句话木马用法每个脚本支持的协议玩法 演示案例某CMS程序文件包含利用-黑盒CTF-南邮大&#xff0c;i春…

ChatGPT 制作转化率分析漏斗图的制作

像这样的转换率漏斗图使用前端可视化技术就可以完成。 使用ChatGPT OpenAI来完成代码的编写。 我们将完整的代码给大家复制到下面: <!DOCTYPE html> <html> <head><meta charset="utf-8"><title>ECharts</title><!-- 引入…

如何在IPhone 14、14 Pro和14 Pro Max上添加屏幕锁定

当你第一次获得iPhone时&#xff0c;系统会提示你为它创建一个密码&#xff0c;这样只有你才能访问它。你应该使用一个必须输入的密码&#xff0c;以便在iPhone 14被唤醒或打开时解锁它。这将提供更高级别的保护。当你打开数据保护时&#xff0c;iPhone上的数据会被加密&#x…

恒运资本:沪指涨逾1%,金融、地产等板块走强,北向资金净买入超60亿元

4日早盘&#xff0c;两市股指盘中强势上扬&#xff0c;沪指、深成指涨超1%&#xff0c;上证50指数涨近2%&#xff1b;两市半日成交约5500亿元&#xff0c;北向资金大举流入&#xff0c;半日净买入超60亿元。 截至午间收盘&#xff0c;沪指涨1.12%报3168.38点&#xff0c;深成指…

Vue——vue3中的ref和reactive数据理解以及父子组件之间props传递的数据

ref()函数 这是一个用来接受一个内部值&#xff0c;返回一个响应式的、可更改的 ref 对象&#xff0c;此对象只有一个指向其内部值的属性 .value。 作用&#xff1a;创建一个响应式变量&#xff0c;使得某个变量在发生改变时可以同步发生在页面上。 模板语句中使用这个变量时…

解决外接显示器后Edge浏览器地址栏等变得很大的问题

解决外接显示器后Edge浏览器地址栏等变得很大的问题 edge设置里外观——触控模式&#xff0c;把触控模式关了

uni-app 之 v-on:click点击事件

uni-app 之 v-on:click点击事件 image.png <template><!-- vue2的<template>里必须要有一个盒子&#xff0c;不能有两个&#xff0c;这里的盒子就是 view--><view>--- v-on:click点击事件 ---<view v-on:click"onclick">{{title}}<…

浅谈Mysql读写分离的坑以及应对的方案 | 京东云技术团队

一、主从架构 为什么我们要进行读写分离&#xff1f;个人觉得还是业务发展到一定的规模&#xff0c;驱动技术架构的改革&#xff0c;读写分离可以减轻单台服务器的压力&#xff0c;将读请求和写请求分流到不同的服务器&#xff0c;分摊单台服务的负载&#xff0c;提高可用性&a…

华为OD机试 - 等和子数组最小和 - 深度优先搜索(Java 2022 Q4 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出 华为OD机试 2023B卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷&#xff09;》…

ApiPost7使用介绍 | HTTP Websocket

一、基本介绍 创建项目&#xff08;团队下面可以创建多个项目节点&#xff0c;每个项目可以创建多个接口&#xff09;&#xff1a; 参数描述库&#xff08;填写参数时自动填充描述&#xff09;&#xff1a; 新建环境&#xff08;前置URL、环境变量很有用&#xff09;&#x…