编辑代码

#include <stdio.h>
int main () {
    //JSRUN引擎2.0,支持多达30种语言在线运行,全仿真在线交互输入输出。 
    printf("Hello world!     - c.jsrun.net.");
    return 0;
}  
#include <stdio.h>

// 获取数组中的最大值
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); // 获取最大值
    int exp; // 指数,用于表示个位、十位、百位等

    // 从个位开始,对每一位进行排序
    for (exp = 1; max / exp > 0; exp *= 10) {
        int output[n]; // 存储排序结果
        int count[10] = {0}; // 用于存储每个桶中的元素个数

        // 统计每个桶中元素的个数
        for (int i = 0; i < n; i++) {
            count[(arr[i] / exp) % 10]++;
        }

        // 将 count[i] 更新为该位置的实际位置
        for (int i = 1; i < 10; i++) {
            count[i] += count[i - 1];
        }

        // 构建排序结果数组
        for (int i = n - 1; i >= 0; i--) {
            output[count[(arr[i] / exp) % 10] - 1] = arr[i];
            count[(arr[i] / exp) % 10]--;
        }

        // 将排序结果复制到原数组
        for (int i = 0; i < n; i++) {
            arr[i] = output[i];
        }
    }
}

// 打印数组元素
void printArray(int arr[], int n) {
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

// 主函数
int main() {
    int arr[] = {170, 45, 75, 90, 802, 24, 2, 66};
    int n = sizeof(arr) / sizeof(arr[0]);

    printf("Original array: ");
    printArray(arr, n);

    radixSort(arr, n);

    printf("Sorted array: ");
    printArray(arr, n);

    return 0;
}
#include <stdio.h>

// 获取数组中的最大值
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); // 获取最大值
    int exp; // 指数,用于表示个位、十位、百位等

    // 从个位开始,对每一位进行排序
    for (exp = 1; max / exp > 0; exp *= 10) {
        int output[n]; // 存储排序结果
        int count[10] = {0}; // 用于存储每个桶中的元素个数

        // 统计每个桶中元素的个数
        for (int i = 0; i < n; i++) {
            count[(arr[i] / exp) % 10]++;
        }

        // 将 count[i] 更新为该位置的实际位置
        for (int i = 1; i < 10; i++) {
            count[i] += count[i - 1];
        }

        // 构建排序结果数组
        for (int i = n - 1; i >= 0; i--) {
            output[count[(arr[i] / exp) % 10] - 1] = arr[i];
            count[(arr[i] / exp) % 10]--;
        }

        // 将排序结果复制到原数组
        for (int i = 0; i < n; i++) {
            arr[i] = output[i];
        }
    }
}

// 打印数组元素
void printArray(int arr[], int n) {
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

// 主函数
int main() {
    int arr[] = {170, 45, 75, 90, 802, 24, 2, 66};
    int n = sizeof(arr) / sizeof(arr[0]);

    printf("Original array: ");
    printArray(arr, n);

    radixSort(arr, n);

    printf("Sorted array: ");
    printArray(arr, n);

    return 0;
}