Java 基数排序算法
在基数排序算法中,元素的排序首先将具有相同位值的单个数字分组,然后按照升序或降序排序。本教程详细解释了基数排序
算法,并演示了 Java 中基数排序的实现。
基数排序算法
按照以下步骤应用基数排序
。
- 首先从输入数组中找到最大元素;然后,该最大数量将用于遍历所有数组成员的重要位置。
- 接下来,一个一个地走过每个重要的地方。我们可以使用任何稳定的排序算法,例如计数排序,对每个重要位置的元素进行排序。
支持六个元素的数组。radix sort
将首先根据单位位置的值对元素进行排序。
然后根据第十位的值对数组的元素进行排序。
假设数组是 [9, 50, 4, 203, 17, 39]
。下图显示了这个数组根据 radix sort
进行了多次排序。
基数排序算法的时间复杂度
下表显示了 radix sort
算法在不同情况下的时间复杂度。
时间复杂度 | 情况 |
---|---|
Ω(n+k) |
最佳情况 |
θ(nk) |
平均情况 |
O(nk) |
最差情况 |
-
最佳情况 - 当不需要排序时,数组已经排序。在最佳情况下,
基数排序
时间复杂度是Ω(n+k)
。 -
平均情况 - 数组元素的顺序混乱,没有正确的降序或升序。在平均情况下,
基数排序
时间复杂度是θ(nk)
。 -
最坏情况 - 当数组元素必须以相反的顺序排序时,例如从升序到降序或从降序到升序。在最坏的情况下,
基数排序
时间复杂度是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 中连接两个列表
发布时间: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 中制作并发列表。并发是在并行运行中运行程序或函数的过程。当多个线程在同一个方法上工作时,它可以减少时间并增加吞吐量。