C语言编写一段基数排序对一组3位数进行排序

时间: 2023-07-27 17:22:51 浏览: 47
以下是一段使用基数排序对一组3位数进行排序的C代码: ```c #include <stdio.h> void radix_sort(int arr[], int n) { int bucket[10][n]; int count[10]; int digit = 0; int max_num = arr[0]; int i, j, k; // 计算最大值和位数 for (i = 0; i < n; i++) { if (arr[i] > max_num) { max_num = arr[i]; } } while (max_num > 0) { digit++; max_num /= 10; } // 对每一位进行排序 for (i = 0; i < digit; i++) { // 每一轮开始前清空桶和计数器 for (j = 0; j < 10; j++) { count[j] = 0; } // 将数字放入桶中 for (j = 0; j < n; j++) { int index = (arr[j] / (int)pow(10, i)) % 10; bucket[index][count[index]] = arr[j]; count[index]++; } // 将桶中的数字复制回原数组 k = 0; for (j = 0; j < 10; j++) { for (int l = 0; l < count[j]; l++) { arr[k++] = bucket[j][l]; } } } } int main() { int arr[] = {321, 108, 589, 304, 123, 573, 437}; int n = sizeof(arr) / sizeof(arr[0]); radix_sort(arr, n); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; } ``` 在这个例子中,我们定义了一个`radix_sort`函数来对一个`int`类型的数组进行排序。首先,我们计算出最大值和数字位数。然后,我们使用桶和计数器对每个数字的每个位数进行排序。在每一轮排序中,我们将数字放入10个桶中,根据当前位数的值将数字分配到桶中。然后,我们按照桶的顺序将数字复制回原始数组中,并重复此过程直到排序完成。最后,我们在`main`函数中调用`radix_sort`并输出排序后的结果。

相关推荐

最新推荐

recommend-type

用C语言实现从文本文件中读取数据后进行排序的功能

是一个十分可靠的程序,这个程序的查错能力非常强悍。程序包含了文件操作,归并排序和字符串输入等多种技术。对大家学习C语言很有帮助,有需要的一起来看看。
recommend-type

c语言编程的几种排序算法比较

排序算法是一种基本并且常用的算法。由于实际工作中处理的数量巨大,所以排序算法 对算法本身的速度要求很高。 而一般我们所谓的算法的性能主要是指算法的复杂度,一般用O方法来表示。在后面我将 给出详细的说明。
recommend-type

C语言实现排序算法之归并排序详解

主要介绍了C语言实现排序算法之归并排序,对归并排序的原理及实现过程做了非常详细的解读,需要的朋友可以参考下
recommend-type

C语言实现3*3数组对角线之和示例

今天小编就为大家分享一篇C语言实现3*3数组对角线之和示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

C语言统计一篇英文短文中单词的个数实例代码

本文通过实例代码给大家介绍的C语言统计一篇英文短文中单词的个数,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

hive中 的Metastore

Hive中的Metastore是一个关键的组件,它用于存储和管理Hive中的元数据。这些元数据包括表名、列名、表的数据类型、分区信息、表的存储位置等信息。Hive的查询和分析都需要Metastore来管理和访问这些元数据。 Metastore可以使用不同的后端存储来存储元数据,例如MySQL、PostgreSQL、Oracle等关系型数据库,或者Hadoop分布式文件系统中的HDFS。Metastore还提供了API,使得开发人员可以通过编程方式访问元数据。 Metastore的另一个重要功能是跟踪表的版本和历史。当用户对表进行更改时,Metastore会记录这些更改,并且可以让用户回滚到
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。