C语言实现----基数排序

42 篇文章 2 订阅
10 篇文章 3 订阅

一、基数排序介绍

基数排序( Radix Sort )是桶排序的扩展,它的基本思想是:将整数按位数切割成不同的数字,然后按每个位数分别比较。

具体做法是:将所有待比较数值统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后,数列就变成一个有序序列。

二、基数排序图文说明 

1. 基数排序图文说明 

通过基数排序对数组{53,3,542,748,14,214,154,63,616}进行排序,它的示意图如下:

在上图中,首先将所有待比较数值统一位数长度,接着从最低位开始,依次进行排序。

1.按照个位数进行排序。

2.按照十位数进行排序。

3.按照百位数进行排序。

排序后,数列就变成了一个有序序列。

2. 基数排序代码

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>

// 获取a中最大值
// 
// 参数说明
// a -- 数组
// b -- 数组长度

int get_max(int a[], int n) {
	int i, max;
	max = a[0];
	for (i = 1; i < n; i++) {
		if (a[i] > max) {
			max = a[i];
		}
	}
	return max;
}

// 对数组按照“某个位数”进行排序(桶排序)
// 
// 参数说明
// 
// a -- 数组
// n -- 数组长度
// exp -- 指数。对数组a按照指数进行排序 
// 例如,对于数组a = {50,3,542,745,2014,154,63,616};
// (01)exp=1 表示按照“个位”对数组a进行排序
// (02)exp=10 表示按照“十位”对数组a进行排序
// (03)exp=100 表示按照“百位”对数组a进行排序
//

void count_sort(int a[], int n, int exp) {
	int *output = (int *)malloc(n*sizeof(int)); // 存储“被排序数据”的临时数组
	int i, buckets[10] = { 0 };
	// 将数据出现的次数存储在buckets[]中
	for (i = 0; i < n; i++) {
		buckets[(a[i] / exp) % 10]++;
	}
	// 更改buckets[i]。目的是让改后的buckets[i]的值,是该数据在output[]中的位置。
	for (i = 1; i < 10; i++) {
		buckets[i] += buckets[i - 1];
	}
	// 将数据存储到临时数组output[]中
	for (i = n - 1; i >= 0; i--) {
		output[buckets[(a[i] / exp) % 10] - 1] = a[i];
		buckets[(a[i] / exp) % 10]--;
	}
	// 将排序好的数据赋值给a[]
	for (i = 0; i < n; i++) {
		a[i] = output[i];
	}
}

// 基数排序
// 
// 参数说明
// 
// a -- 数组
// n -- 数组长度
// 
void radix_sort(int a[], int n) {
	int exp;
	// 指数。当对数组按各位进行排序时,exp=1;按十位进行排序时,exp=10。
	int max = get_max(a, n);// 数组a中的最大值
	// 从个位开始,对数组a按指数进行排序
	for (exp = 1; max / exp > 0; exp *= 10) {
		count_sort(a, n, exp);
	}
}



int main() {
	int arr[] = { 53,3,542,748,14,214,154,63,616 };
	radix_sort(arr, 9);
	for (int i = 0; i < 9; i++) {
		printf("%d ", arr[i]);
	}
	printf("\n");

	return 0;
}

radix_sort ( a , n )的作用是对数组 a 进行排序。

1.首先通过 get_max ( a )获取数组 a 中的最大值。获取最大值的目的是计算出数组 a 的最大指数。

2.获取到数组 a 中的最大指数之后,再从指数1开始,根据位数对数组 a 中的元素进行排序。排序的时候采用了桶排序。

3.count_sort ( a , n , exp )的作用是对数组 a 按照指数 exp 进行排序。

下面简单介绍一下对数组{53,3,542,748,14,214,154,63,616}按个位数进行排序的流程。

(01)个位的数值范围是[0,10)。因此,参见桶数组 buckets[] ,将数组按照个位数值填加到桶中。

(02)接着是根据桶数组 buckets [] 来进行排序。假设将排序后的数组存在 output []中;找出 output []和 buckets []之间的联系就可以对数据进行排序了。

  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基数排序算法是一种稳定排序算法,适用于数值比较大的数据之间的排序。它不涉及元素之间的比较,而是根据基数将数据存放到相应的“桶”里,经过多趟排序过程,最终实现对一组散乱数据的排序。 基数排序实现思路如下: 1. 首先确定待排序数组中最大值的位数,记为max_digits。 2. 创建10个桶,对每个桶进行计数初始化。 3. 从低位到高位,依次对待排序数组中的元素进行入桶操作。 4. 将桶中的元素按顺序依次取出,得到新的排序结果。 5. 重复第3和第4步,直到所有元素中的最高位已经处理完毕。 6. 最终得到的排序结果就是基数排序的结果。 下面是基数排序C语言实现示例: ```c #include <stdio.h> // 获取数组中最大值的位数 int getMaxDigits(int arr[], int n) { int max = arr[0]; for (int i = 1; i < n; i++) { if (arr[i] > max) { max = arr[i]; } } int digits = 0; while (max > 0) { max /= 10; digits++; } return digits; } // 对数组进行基数排序 void radixSort(int arr[], int n) { int max_digits = getMaxDigits(arr, n); int count[10]; int bucket[n]; int divisor = 1; for (int i = 0; i < max_digits; i++) { // 初始化计数数组和桶 for (int j = 0; j < 10; j++) { count[j] = 0; } // 统计每个桶中的元素个数 for (int j = 0; j < n; j++) { int digit = (arr[j] / divisor) % 10; count[digit]++; } // 计算每个桶中元素的起始位置 for (int j = 1; j < 10; j++) { count[j] += count[j - 1]; } // 将元素按照当前位的值放入对应的桶中 for (int j = n - 1; j >= 0; j--) { int digit = (arr[j] / divisor) % 10; bucket[count[digit] - 1] = arr[j]; count[digit]--; } // 将桶中的元素按顺序放回原数组 for (int j = 0; j < n; j++) { arr[j] = bucket[j]; } divisor *= 10; } } int main() { int arr[] = {53, 89, 150, 36, 633, 233, 197, 9, 473, 27}; int n = sizeof(arr) / sizeof(arr[0]); printf("原数组:"); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } radixSort(arr, n); printf("\n排序后的数组:"); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值