91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

平塘县| 宜兰县| 县级市| 凭祥市| 临安市| 长寿区| 江西省| 英山县| 沧源| 河西区| 正宁县| 来宾市| 进贤县| 宁城县| 平利县| 岑巩县| 诏安县| 申扎县| 阿勒泰市| 永和县| 电白县| 宣武区| 泰兴市| 莲花县| 贵阳市| 荔波县| 临桂县| 正安县| 宜城市| 江川县| 西林县| 东安县| 蓬溪县| 东明县| 竹山县| 象山县| 图木舒克市| 乌拉特中旗| 建德市| 遂宁市| 江孜县|