簡體   English   中英

逆向工程師排序算法

[英]Reverse Engineer Sorting Algorithm

我給了3種算法進行逆向工程並解釋它們如何工作,到目前為止,我已經確定了給我一種快速排序算法和一個氣泡排序算法。 但是我不確定這是什么算法。 我了解快速排序和氣泡排序的工作原理,但是我無法理解這種算法。 我不確定變量是什么,希望有人可以告訴我這里發生了什么:

public static ArrayList<Integer> SortB(ArrayList<Integer> a)
{
    ArrayList<Integer> array = CopyArray(a);
    Integer[] zero = new Integer[a.size()];
    Integer[] one = new Integer[a.size()];
    int i,b;
    Integer x,p;
    //Change from 8 to 32 for whole integers - will run 4 times slower
    for(b=0;b<8;++b)
    {
        int zc = 0;
        int oc = 0;
        for(i=0;i<array.size();++i)
        {
            x = array.get(i);
            p = 1 << b;
            if ((x & p) == 0)
            {
                zero[zc++] = array.get(i);
            }
            else
            {
                one[oc++] = array.get(i);
            }
        }
        for(i=0;i<oc;++i) array.set(i,one[i]);
        for(i=0;i<zc;++i) array.set(i+oc,zero[i]);
    }
    return(array);
}

這是一個Radix Sort ,僅限於最低有效8位。 除非將循環更改為32次而不是8次,否則它不會完成排序。

每次迭代處理一次b 通過向左移動1b准備稱為p的掩碼。 這樣會產生二進制的2-1,2,4,8,...,或1,10,100,1000,10000,...的冪。

對於每一位,將位b設置為10的原始數組中的元素數分成兩個存儲桶,分別稱為onezero 分離結束后,將元素放回原始數組,然后算法進行下一次迭代。

此實現使用的存儲量是原始數組大小的兩倍,並且通過該數組的時間總計為16次(完整版本中為64次-每次讀取一次,每次寫入一次數據)。 該算法的漸近復雜度是線性的。

在我看來,一點點的基數排序,但似乎在向后排序。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM