| import java.util.ArrayList;import java.util.Arrays;
 import java.util.Collections;
 import java.util.List;
 
 /*
 * Java程序使用基数排序算法对整数数组进行排序。
 * input: [80, 50, 30, 10, 90, 60, 0, 70, 40, 20, 50]
 * output: [0, 10, 20, 30, 40, 50, 50, 60, 70, 80, 90]
 *
 * 解决方案的时间复杂性:
 *     最佳情况O(n); 平均情况O(n); 最坏情况O(n ^ 2)。
 *
 */
 
 public class BuckeSort {
 
 public static void main(String args) {
 
 System.out.println("Bucket sort in Java");
 int input = { 80, 50, 30, 10, 90, 60, 0, 70, 40, 20, 50 };
 
 System.out.println("integer array before sorting");
 System.out.println(Arrays.toString(input));
 
 // sorting array using radix Sort Algorithm
 bucketSort(input);
 
 System.out.println("integer array after sorting using bucket sort algorithm");
 System.out.println(Arrays.toString(input));
 
 }
 
 /<strong>
 *
 * @param input
 */
 public static void bucketSort(int input) {
 // get hash codes
 final int code = hash(input);
 
 // create and initialize buckets to ArrayList: O(n)
 List buckets = new List[code[1]];
 for (int i = 0; i < code[1]; i++) {
 buckets<i> = new ArrayList();
 }
 
 // distribute data into buckets: O(n)
 for (int i : input) {
 buckets[hash(i, code)].add(i);
 }
 
 // sort each bucket O(n)
 for (List bucket : buckets) {
 Collections.sort(bucket);
 }
 
 int ndx = 0;
 // merge the buckets: O(n)
 for (int b = 0; b < buckets.length; b++) {
 for (int v : buckets<strong>) {
 </strong></i>  input[ndx++] = v;
 }
 }
 }
 
 /</strong>
 *
 * @param input
 * @return an array containing hash of input
 */
 private static int hash(int input) {
 int m = input[0];
 for (int i = 1; i < input.length; i++) {
 if (m < input) {
 m = input;
 }
 }
 return new int { m, (int) Math.sqrt(input.length) };
 }
 
 /**
 *
 * @param i
 * @param code
 * @return
 */
 private static int hash(int i, int code) {
 return (int) ((double) i / code[0] * (code[1] - 1));
 }
 
 }
 
 
 Output
 Bucket sort in Java
 integer array before sorting
 [80, 50, 30, 10, 90, 60, 0, 70, 40, 20, 50]
 integer array after sorting using bucket sort algorithm
 [0, 10, 20, 30, 40, 50, 50, 60, 70, 80, 90]
 
 |