zoukankan      html  css  js  c++  java
  • [转]基数排序

    (java版)

    import java.util.ArrayList;
    import java.util.List;

    public class radixSort {

    public static void sort(int[] a){
    //首先确定排序的趟数
    int max = a[0];
    for(int i=1; i<a.length; i++){
    if(a[i] > max){
    max = a[i];
    }
    }
    int time = 0;
    //判断位数
    while(max > 0){
    max /= 10;
    time++;
    }
    //建立10个队列
    List<ArrayList> queue = new ArrayList<ArrayList>();

    for(int i=0; i<10; i++){
    ArrayList<Integer> queue1 = new ArrayList<Integer>();
    queue.add(queue1);
    }
    //进行time次分配和收集
    for(int i=0; i<time; i++){
    //分配数组元素
    for(int j=0; j<a.length; j++){
    //得到数字的第time+1位数
    int x = a[j] % (int)Math.pow(10, i+1)/(int)Math.pow(10, i);
    ArrayList<Integer> queue2 = queue.get(x);
    queue2.add(a[j]);
    queue.set(x,queue2);
    }
    int count = 0;//元素计数器
    //收集队列元素
    for(int k=0; k<10; k++){
    while(queue.get(k).size() > 0){
    ArrayList<Integer> queue3 = queue.get(k);
    a[count] = queue3.get(0);
    queue3.remove(0);
    count++;
    }
    }
    }
    }

    public static void main(String[] args) {
    int[] a = {0,2,5,43,32,65,43,21,87,1};
    sort(a);
    for(int i =0; i<a.length; i++)
    System.out.print(a[i]+" ");
    }

    }

  • 相关阅读:
    第二阶段第九天
    第二阶段第八天
    一轮项目冲刺——移山小分队(3)
    一轮项目冲刺——移山小分队(2)
    典型用户和用户场景
    一轮项目冲刺——移山小分队
    寻找水王
    NABCD需求分析
    每日记录01
    二维数组最大连通和的求解
  • 原文地址:https://www.cnblogs.com/tangtang-123/p/4436048.html
Copyright © 2011-2022 走看看