当前位置: 首页 > news >正文

计数排序(C语言)

一、步骤

1.首先,遍历数组统计出相同元素出现的次数

2.根据统计的结果将序列收回到原来的数组

方法:我们可以建立一个临时数组用来存储元素出现的次数,然后用该数组的下标表示该元素(即假设i为临时数组的下标,a[i]为临时数组下标为i的元素的值,则i就是原数组的值,而a[i]是该值出现的次数),但是这样直接创建会面临着一个问题,那就是可能会浪费掉大量的空间,假如一个数组为[100,105,101,110,100,106,104]这样创建数组的话[0,99]的空间会全部被浪费。因此为了解决这一问题,我们可以遍历一遍数组,获得最大值max和最小值min,然后创建一个大小为max-min+1的数组,其中min表示为数组下标为0,max为数组下标i-1。

图片详述:

二、代码

void CountSort(int* a, int n)
{int max = a[0], 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 size = max - min + 1; //创建临时数组的大小int* tmp = (int*)malloc(sizeof(int) * size);memset(tmp, 0, sizeof(int) * size); //将临时数组中的随机值全部设为0for (int i = 0; i < n; i++)  //遍历数组统计相同元素出现的次数{tmp[a[i] - min]++;}int j = 0;for (int i = 0; i < size; i++) //开始排序{while (tmp[i]--){a[j++] = i + min; //下标加最小值就是原来元素的大小}}free(tmp);
}

http://www.lryc.cn/news/485406.html

相关文章:

  • LabVIEW弧焊参数测控系统
  • Android笔记(三十七):封装一个RecyclerView Item曝光工具——用于埋点上报
  • 【Linux】内核模版加载modprobe | lsmod
  • Android从Drawable资源Id直接生成Bitmap,Kotlin
  • 蓝桥杯——数组
  • 在Flutter中,禁止侧滑的方法
  • 黑盒测试案例设计方法的使用(1)
  • 第二十一章 TCP 客户端 服务器通信 - 客户端OPEN命令
  • pycharm报错:no module named cv2.cv2
  • Android音视频直播低延迟探究之:WLAN低延迟模式
  • docker 部署freeswitch(非编译方式)
  • OpenHarmony的公共事件
  • 深度学习transformer
  • 低成本出租屋5G CPE解决方案:ZX7981PG/ZX7981PM WIFI6千兆高速网络
  • 【黑马点评debug日记】redis登录跳转不成功
  • C#自定义特性-SQL
  • 协方差矩阵及其计算方法
  • 【OH】openHarmony开发环境搭建(基于windows子系统WSL)
  • Visual Studio Code 端口转发功能详解
  • Android Framework AMS(14)ContentProvider分析-1(CP组件应用及开机启动注册流程解读)
  • Three.js PBR材质
  • 智谱AI清影升级:引领AI视频进入音效新时代
  • 嵌入式硬件电子电路设计(五)MOS管详解(NMOS、PMOS、三极管跟mos管的区别)
  • Centos 9 安装 PostgreSQL 16 并支持远程访问
  • Dubbo源码解析(三)
  • HarmonyOS Next星河版笔记--界面开发(5)
  • Spring Boot3 实战案例合集上线了
  • 在Ubuntu 24.04 LTS上安装飞桨PaddleX
  • Homebrew 命令大全
  • Docker+Django项目部署-从Linux+Windows实战