基数排序|RadixSort|C++实现
发布人:shili8
发布时间:2025-01-16 15:04
阅读次数:0
**基数排序(Radix Sort)概述**
基数排序是一种非比较型整数排序算法,适用于整数或定长字符串的排序。它通过分配每个元素到一个桶中,然后将桶中的元素重新排列为有序序列来实现排序。
**基数排序流程**
1. **确定基数**:首先,我们需要确定要根据哪个位进行排序。这可以是数字的个位、十位或百位等。
2. **分配到桶中**:然后,我们将每个元素根据指定的基数值分配到一个桶中。桶中的元素都有相同的基数值。
3. **重新排列**:最后,我们将桶中的元素重新排列为有序序列。
**C++实现**
下面是基数排序的 C++ 实现:
cpp#include <iostream> using namespace std; // 定义一个函数来计算数字的最大位数int getMax(int arr[], int n) { int max = arr[0]; for (int i =1; i < n; i++) { if (arr[i] > max) max = arr[i]; } return max; } // 基数排序函数void radixsort(int arr[], int n) { // 确定基数 int max = getMax(arr, n); for (int exp =1; max / exp >0; exp *=10) // 分配到桶中并重新排列 countSort(arr, n, exp); } // 计算排序后的数字个位、十位等的函数void countSort(int arr[], int n, int exp) { int output[n]; int count[10] = {0}; // 分配到桶中 for (int i =0; i < n; i++) ++count[(arr[i] / exp) %10]; // 计算累计值 for (int i =1; i < 10; i++) count[i] += count[i -1]; //重新排列 int i = n -1; while (i >=0) { output[count[(arr[i] / exp) %10] -1] = arr[i]; --count[(arr[i] / exp) %10]; --i; } // 将输出数组复制回原数组 for (int i =0; i < n; i++) arr[i] = output[i]; } // 测试基数排序函数void printArray(int arr[], int n) { cout << "Sorted array is: "; for (int i =0; i < n; i++) cout << arr[i] << " "; cout << endl; } // 主函数int main() { int arr[] = {170,45,75,90,802,24,2,66}; int n = sizeof(arr) / sizeof(arr[0]); radixsort(arr, n); printArray(arr, n); return0; }
**输出**
Sorted array is:22445667590170802**注释**
* `getMax` 函数用于计算数字的最大位数。
* `radixsort` 函数是基数排序的主函数,负责确定基数并进行分配和重新排列。
* `countSort` 函数用于根据指定的基数值对元素进行分配到桶中,并将桶中的元素重新排列为有序序列。
* `printArray` 函数用于打印排序后的数组。
**总结**
本文介绍了基数排序(Radix Sort)的基本概念和流程,提供了 C++ 实现的代码示例。通过阅读这篇文章,你应该能够理解基数排序的原理,并且可以使用 C++语言来实现基数排序算法。