一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java語言實現基數排序代碼分享

Java語言實現基數排序代碼分享

2021-03-07 11:48zengzhihua Java教程

這篇文章主要介紹了Java語言實現基數排序代碼分享,具有一定借鑒價值,需要的朋友可以參考下。

算法思想:依次按個位、十位...來排序,每一個pos都有分配過程和收集過程,array[i][0]記錄第i行數據的個數。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package sorting;
/**
 * 平均O(d(n+r)),最好O(d(n+r)),最壞O(d(n+r));空間復雜度O(n+r);穩定;較復雜
 * d為位數,r為分配后鏈表的個數
 * @author zeng
 *
 */
public class RadixSort {
    //pos=1表示個位,pos=2表示十位
    public static int getNumInPos(int num, int pos) {
        int tmp = 1;
        for (int i = 0; i < pos - 1; i++) {
            tmp *= 10;
        }
        return (num / tmp) % 10;
    }
    //求得最大位數d
    public static int getMaxWeishu(int[] a) {
        int max = a[0];
        for (int i = 0; i < a.length; i++) {
            if (a[i] > max)
                    max = a[i];
        }
        int tmp = 1, d = 1;
        while (true) {
            tmp *= 10;
            if (max / tmp != 0) {
                d++;
            } else
                    break;
        }
        return d;
    }
    public static void radixSort(int[] a, int d) {
        int[][] array = new int[10][a.length + 1];
        for (int i = 0; i < 10; i++) {
            array[i][0] = 0;
            // array[i][0]記錄第i行數據的個數
        }
        for (int pos = 1; pos <= d; pos++) {
            for (int i = 0; i < a.length; i++) {
                // 分配過程
                int row = getNumInPos(a[i], pos);
                int col = ++array[row][0];
                array[row][col] = a[i];
            }
            for (int row = 0, i = 0; row < 10; row++) {
                // 收集過程
                for (int col = 1; col <= array[row][0]; col++) {
                    a[i++] = array[row][col];
                }
                array[row][0] = 0;
                // 復位,下一個pos時還需使用
            }
        }
    }
    public static void main(String[] args) {
        int[] a = { 49, 38, 65, 197, 76, 213, 27, 50 };
        radixSort(a, getMaxWeishu(a));
        for (int i : a)
              System.out.print(i + " ");
    }
}

關注一下運行結果:

Java語言實現基數排序代碼分享

總結

以上就是本文關于Java語言實現基數排序代碼分享的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他Java相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

原文鏈接:http://www.cnblogs.com/zengzhihua/p/4456753.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人免费视频 | 婷婷在线成人免费观看搜索 | 九九九九在线精品免费视频 | 99久久精品免费看国产一区 | 四虎影院2019 | 鸭子玩富婆流白浆视频 | 久久99精品国产免费观看 | 久久精品国产亚洲AV蜜臀 | 美女污视频在线观看 | 成人网中文字幕色 | 五月天精品在线 | 美女啪啪国产 | 99视频精品全部 在线 | 精品一久久香蕉国产二月 | 99爱在线精品视频免费观看9 | 羞羞答答免费人成黄页在线观看国产 | 国产成人www免费人成看片 | 久久AV国产麻豆HD真实乱 | 久久99国产综合精品AV蜜桃 | 1024免费观看完整版在线播放 | 日韩一区二区三区在线 | 日韩v | 精品国产一区二区三区久久久蜜臀 | 啊皇上你好大要知画 | 俺去啦最新| 性柔术18性13处交 | caoporm国产精品视频免费 | 国士李风起全文在线阅读 | 国产精品午夜性视频网站 | 亚洲第9页 | 把美女屁股眼扒开图片 | 狠狠综合久久综合网站 | 亚洲另类老妇videos | 精品亚洲国产一区二区 | www.日日爱 | 日本高清视频网站www | 91制片厂官网 | ass亚洲熟妇毛茸茸pics | 2020年最新国产精品视频免费 | 色图大全 | 网红刘婷hd国产高清 |