溫馨提示×

溫馨提示×

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

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

Java中怎么實現基數排序

發(fā)布時間:2021-06-22 15:24:14 來源:億速云 閱讀:153 作者: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++)//將前一個循環(huán)生成的桶里的數據覆蓋到原數組中用于保存這一位的排序結果
            {
                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中怎么實現基數排序,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

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

AI