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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: tube4欧美4 | 欧美bbb人妖 | bl超h 高h 污肉快穿np | 色漫在线观看 | 91精品国产免费久久国语蜜臀 | 2022av小四郎的最新地址 | 亚洲欧美综合区自拍另类 | juy799大岛优香在线观看 | 火影小南被爆羞羞网站进入 | hezyo加勒比一区二区三区 | 午夜久久久久久亚洲国产精品 | 国产精品aaa | 久久99视热频国只有精品 | 红杏网| 热99精品在线| 国色天香社区视频免费观看3 | 亚洲视频观看 | 亚洲国产AV一区二区三区四区 | 国产在线步兵一区二区三区 | 国产乱人乱精一区二区视频密 | 日韩毛片在线 | 国产高清专区 | 男女福利视频 | 美女福利视频午夜在线 | 人人澡 人人澡碰人人看软件 | 亚洲精品国产精品麻豆99 | 国产免费看视频 | 国产在线98福利播放视频免费 | 草草影院永久在线观看 | 非洲特级特黄aa大片 | 亚洲欧美一区二区三区在饯 | 国产亚洲精品综合在线网址 | 无限在线看免费视频大全 | 精品久久久久久久国产潘金莲 | 人禽l交视频在线播放 视频 | 成人中文字幕在线观看 | 超级碰在线视频 | 福利片福利一区二区三区 | 男人与雌性宠物交啪啪小说 | 国产裸舞在线一区二区 | 色综合亚洲精品激情狠狠 |