国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久久久久久久久免费视频 | 精品www | 国产精品美女久久久久高潮 | 两性视频久久 | 日韩精品视频一区二区三区 | 亚洲精品午夜 | 色乱码一区二区三区网站 | 久久久久久久国产精品 | 日韩精品中文字幕在线观看 | 日韩成人av电影 | 国内精品久久久久久久影视红豆 | 欧美日韩福利 | 自拍视频一区 | 精品一区二区三区免费 | 91视频网页版 | 国产精品成人一区二区 | 久久99精品视频 | 国产黄色电影 | 中文字幕在线观看日韩 | 国产精品久久久久久久久久久久久久 | 国产精品99久久久久久动医院 | 欧美顶级毛片在线播放 | 中文字幕在线免费视频 | 91免费影视 | 久久久中文 | 亚洲激情在线观看 | 91麻豆精品国产91久久久久久久久 | 久久爱综合 | 中文字幕一区二区三区乱码在线 | 欧美精品乱码久久久久久按摩 | 自拍偷拍欧美 | 欧美视频在线看 | av黄色在线 | 91精品久久久久久久久久 | 中文字幕av在线播放 | 久久精品一级 | 亚洲欧美在线视频 | 亚洲综合一区二区 | 日韩精品免费 | 狠狠躁夜夜躁人人爽天天高潮 | 国产成人精品综合 |