亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中怎么實現基數排序

發布時間:2021-06-22 15:24:14 來源:億速云 閱讀:160 作者:Leah 欄目:大數據

本篇文章為大家展示了Java中怎么實現基數排序,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

基數排序(radix sort)又稱桶排序(bucket sort)

public class RadixSort {
    private static void radixSort(int[] array,int d)
    {
        int n=1;//代表位數對應的數:1,10,100...
        int k=0;//保存每一位排序后的結果用于下一位的排序輸入
        int length=array.length;
        int[][] bucket=new int[10][length];//排序桶用于保存每次排序后的結果,這一位上排序結果相同的數字放在同一個桶里
        int[] order=new int[length];//用于保存每個桶里有多少個數字
        while(n<d)
        {
            for(int num:array) //將數組array里的每個數字放在相應的桶里
            {
                int digit=(num/n)%10;
                bucket[digit][order[digit]]=num;
                order[digit]++;
            }
            for(int i=0;i<length;i++)//將前一個循環生成的桶里的數據覆蓋到原數組中用于保存這一位的排序結果
            {
                if(order[i]!=0)//這個桶里有數據,從上到下遍歷這個桶并將數據保存到原數組中
                {
                    for(int j=0;j<order[i];j++)
                    {
                        array[k]=bucket[i][j];
                        k++;
                    }
                }
                order[i]=0;//將桶里計數器置0,用于下一次位排序
            }
            n*=10;
            k=0;//將k置0,用于下一輪保存位排序結果
        }

    }
    public static void main(String[] args)
    {
        int[] A=new int[]{73,22, 93, 43, 55, 14, 28, 65, 39, 81};
        radixSort(A, 100);
        for(int num:A)
        {
            System.out.println(num);
        }
    }
}

上述內容就是Java中怎么實現基數排序,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

双辽市| 易门县| 青龙| 合作市| 衡阳县| 宜君县| 土默特右旗| 宝山区| 孝义市| 喀喇沁旗| 滨海县| 奉贤区| 平度市| 蛟河市| 屏边| 鲁山县| 神池县| 康马县| 浦北县| 绍兴市| 西安市| 平顶山市| 阿克苏市| 阜宁县| 电白县| 新营市| 嘉定区| 杨浦区| 郯城县| 松滋市| 荆州市| 长垣县| 南漳县| 楚雄市| 普格县| 黄陵县| 浪卡子县| 贞丰县| 宁陵县| 枣阳市| 乌兰察布市|