迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

Java 基数排序算法

作者:迹忆客 最近更新:2023/10/16 浏览次数:

在基数排序算法中,元素的排序首先将具有相同位值的单个数字分组,然后按照升序或降序排序。本教程详细解释了基数排序算法,并演示了 Java 中基数排序的实现。


基数排序算法

按照以下步骤应用基数排序

  1. 首先从输入数组中找到最大元素;然后,该最大数量将用于遍历所有数组成员的重要位置。
  2. 接下来,一个一个地走过每个重要的地方。我们可以使用任何稳定的排序算法,例如计数排序,对每个重要位置的元素进行排序。

支持六个元素的数组。radix sort 将首先根据单位位置的值对元素进行排序。

然后根据第十位的值对数组的元素进行排序。

假设数组是 [9, 50, 4, 203, 17, 39]。下图显示了这个数组根据 radix sort 进行了多次排序。

基数排序

基数排序算法的时间复杂度

下表显示了 radix sort 算法在不同情况下的时间复杂度。

时间复杂度 情况
Ω(n+k) 最佳情况
θ(nk) 平均情况
O(nk) 最差情况
  1. 最佳情况 - 当不需要排序时,数组已经排序。在最佳情况下,基数排序时间复杂度是Ω(n+k)
  2. 平均情况 - 数组元素的顺序混乱,没有正确的降序或升序。在平均情况下,基数排序时间复杂度是θ(nk)
  3. 最坏情况 - 当数组元素必须以相反的顺序排序时,例如从升序到降序或从降序到升序。在最坏的情况下,基数排序时间复杂度是 O(nk)

基数排序算法的伪代码

基数排序算法的伪代码如下。

Radix_Sort(Input_Array)
    MAX = largest number in the input array
    DIGIT = number of digits in the largest number
    Now, create DIGIT buckets of size 0 - 9
    for x -> 0 to DIGIT
        sort the elements according to any stable sort

Java 中的基数排序算法实现

使用计数排序,让我们实现基数排序算法。参见示例:

package delftstack;

import java.util.Arrays;

public class Radix_Sort {

    public static void main(String args[]) {
        int[] input_array = { 9, 50, 4, 203, 17, 39};
        int array_size = input_array.length;
        Radix_Sort RadixSort = new Radix_Sort();
        RadixSort.Radix_Sort(input_array, array_size);
        System.out.println("Sorted Array Using Radix Sort: ");
        System.out.println(Arrays.toString(input_array));
    }


    // Counting sort to sort the elements on the basis of significant places
    void Counting_Sort(int input_array[], int array_size, int number_place) {
        int[] output_array = new int[array_size + 1];
        int max_number = input_array[0];
        for (int x = 1; x < array_size; x++) {
            if (input_array[x] > max_number) {
                max_number = input_array[x];
            }
        }
        int[] count_array = new int[max_number + 1];

        for (int x = 0; x < max_number; ++x) {
        	count_array[x] = 0;
        }
        // Calculating the count of elements
        for (int x = 0; x < array_size; x++) {
        	count_array[(input_array[x] / number_place) % 10]++;
        }
        // Calculating the cumulative count
        for (int x = 1; x < 10; x++) {
        	count_array[x] += count_array[x - 1];
        }
        // Sorting the elements
        for (int x = array_size - 1; x >= 0; x--) {
        	output_array[count_array[(input_array[x] / number_place) % 10] - 1] = input_array[x];
        	count_array[(input_array[x] / number_place) % 10]--;
        }

        for (int x = 0; x < array_size; x++) {
            input_array[x] = output_array[x];
        }
    }

    // Get the largest element from input array
    int Get_Max(int input_array[], int array_size) {
        int max_number = input_array[0];
        for (int i = 1; i < array_size; i++) {
            if (input_array[i] > max_number) {
            	max_number = input_array[i];
            }
        }
        return max_number;
    }

    // Implement the radix sort
    void Radix_Sort(int input_array[], int array_size) {

        // Get the maximum number
        int max_number = Get_Max(input_array, array_size);

        // Apply the counting sort based on significant place value.
        for (int number_place = 1; max_number / number_place > 0; number_place *= 10) {
        	Counting_Sort(input_array, array_size, number_place);
        }
    }
}

上面的代码在 counting sort 的帮助下实现了基数排序。见输出:

Sorted Array Using Radix Sort:
[4, 9, 17, 39, 50, 203]

上一篇:如何在 Java 中连接两个列表

下一篇:没有了

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

如何在 Java 中连接两个列表

发布时间:2023/10/17 浏览次数:99 分类:Java

在 java 中可以使用不同的方法来连接两个列表,而不改变原来的列表,比如流、参数化构造函数、Predeclared List 和 addAll()方法。

如何在 Java 中创建一个新的列表

发布时间:2023/10/17 浏览次数:84 分类:Java

本文介绍了在 Java 中创建新列表的方法本教程将讨论了在 Java 中创建不同类型列表的方法。Java 中的列表 List 是一个接口,由 ArrayList、LinkedList、Vector 和 Stack 实现。

如何在 Java 中打印列表

发布时间:2023/10/17 浏览次数:73 分类:Java

它通过实例讨论了如何在 Java 中打印出列表的每一个元素。我们将介绍一些可以打印出 Java 中所有列表项的方法。在示例中,我们将使用模型类来演示如何创建模型对象列表,然后在其中打印元

在 Java 中初始化字符串列表

发布时间:2023/10/17 浏览次数:69 分类:Java

在本教程中,我们将看到在 Java 中初始化字符串列表的各种方法。由于列表是一个接口,我们不能直接将其实例化,我们可以使用 ArrayList,LinkedList 和 Vector 来实例化一个列表。

Java 中遍历列表

发布时间:2023/10/16 浏览次数:113 分类:Java

这篇文章将要遍历 Java 中列表的所有元素。本教程介绍了如何遍历 Java 中的列表,并列出了一些示例代码来理解该主题。列表是 Java 中的一个接口,具有多个实现类,例如 ArrayList,LinkedList 等。

在 Java 中遍历链接列表

发布时间:2023/10/16 浏览次数:82 分类:Java

本文介绍如何遍历 Java 中的链表链表是数据元素的线性有序集合。元素的排列在存储器中无处不在或随机的位置。

Java 中的连接列表

发布时间:2023/10/16 浏览次数:103 分类:Java

本文介绍了 Java 中的列表连接。可以动态增加的有序元素集合称为 List 集合。它被表示为一个 node 元素,每个节点都包含一个到下一个节点和元素的 reference。我们可以对列表集合执行的操作包

在 Java 中对列表进行排序

发布时间:2023/10/16 浏览次数:169 分类:Java

列表是一个有序集合,可以以任何顺序存储项目。我们可以将传统算法应用于列表。本教程将演示如何使用不同的函数在 Java 中对列表进行排序。

在 Java 中创建并发列表

发布时间:2023/10/16 浏览次数:127 分类:Java

本文介绍如何在 Java 中制作并发列表。并发是在并行运行中运行程序或函数的过程。当多个线程在同一个方法上工作时,它可以减少时间并增加吞吐量。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便