排序算法-基数排序法(RadixSort)

排序算法-基数排序法(RadixSort)

1、说明

基数排序法与我们之前讨论的排序法不太一样,并不需要进行元素之间的比较操作,而是属于一种分配模式排序方式。

基数排序法比较的方向可分为最高位优先(Most Significant Digit First,MSD)和最低位优先(Least Significant Digit First,LSD)两种。MSD是从最左边的位数开始比较的,而LSD则是从最右边的位数开始比较的。

2、算法分析

  1. 在所有情况下,时间复杂度均为,k是原始数据的最大值。
  2. 基数排序法是稳定排序法。
  3. 基数排序法要使用很大的额外空间来存放列表数据,其空间复杂度为,n是原始数据的个数,p是数据字符数。
  4. 若n很大,p固定或很小,则此排序法的效率很高。

3、C++代码

cpp 复制代码
#include<iostream>
#include<iomanip>
using namespace std;

void PrintData(int data[], int size) {
	for (int i = 0; i < size; i++) {
		cout << data[i] << " ";
	}
	cout << endl;
}

void SetData(int data[], int size) {
	srand(time(nullptr));
	for (int i = 0; i < size; i++) {
		data[i] = rand() % 999 + 1;
	}
}

void Radix(int data[], int size) {
	for (int n = 1; n <= 100; n *= 10) {
		int temp[10][100] = { 0 };
		for (int i = 0; i < size; i++) {
			int m = (data[i] / n) % 10;
			temp[m][i] = data[i];
		}

		int k = 0;
		for (int i = 0; i < 10; i++) {
			for (int j = 0; j < size; j++) {
				if (temp[i][j] != 0) {
					data[k] = temp[i][j];
					k++;
				}
			}
		}
		cout << "经过" << setw(3) << n << "位排序后:";
		PrintData(data, size);
	}
}

int main() {
	
	int size = 20;
	int* data = new int[size];
	SetData(data, size);
	cout << "原始数据:";
	PrintData(data, size);
	cout << "---------------------------------" << endl;
	Radix(data, size);
	cout << "---------------------------------" << endl;
	cout << "最终数据:";
	PrintData(data, size);
	return 0;
}

输出结果

相关推荐
数据小爬虫@5 分钟前
如何高效利用Python爬虫按关键字搜索苏宁商品
开发语言·爬虫·python
ZJ_.7 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
Narutolxy12 分钟前
深入探讨 Go 中的高级表单验证与翻译:Gin 与 Validator 的实践之道20241223
开发语言·golang·gin
XiaoLeisj18 分钟前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Hello.Reader19 分钟前
全面解析 Golang Gin 框架
开发语言·golang·gin
禁默30 分钟前
深入浅出:AWT的基本组件及其应用
java·开发语言·界面编程
yuyanjingtao33 分钟前
CCF-GESP 等级考试 2023年9月认证C++四级真题解析
c++·青少年编程·gesp·csp-j/s·编程等级考试
Jasmine_llq37 分钟前
《 火星人 》
算法·青少年编程·c#
Code哈哈笑39 分钟前
【Java 学习】深度剖析Java多态:从向上转型到向下转型,解锁动态绑定的奥秘,让代码更优雅灵活
java·开发语言·学习