在標準庫算法中,next_permutation可以計算一組數(shù)據(jù)的全排列,下面是簡單的剖析
全椒網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)公司2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
首先查看STL中函數(shù)原型:
templatebool next_permutation (BidirectionalIterator first, BidirectionalIterator last ); template bool next_permutation (BidirectionalIterator first, BidirectionalIterator last, Compare comp);
兩個重載函數(shù)。第二個帶謂詞參數(shù)comp,默認謂詞函數(shù)為“”
下面為一個例子:
#include#include using namespace std; typedef bool (*COMP)(int,int); bool Compare(int a,int b) { return !(a 運行結(jié)果:
下圖是在Linux下stl_algo.h中next_permutation的部分代碼:
如果要比較的數(shù)列中只有一個元素的話返回直接false;否則使變量__i指數(shù)列的最后一個元素,進入循環(huán) ;
從最右邊邊開始比較倆個相鄰的元素,直到找到左邊比右邊小的那兩個數(shù),左邊那個就是待交換的數(shù)
再從最右邊開始,找比代替換的那個數(shù)大的第一個元素,然后交換這兩個數(shù),交換之后反轉(zhuǎn)被替換元素之后的所有元素
原排列 中間轉(zhuǎn)換 值
1,2,3,4 3,2,1 ((3 * (3) + 2) * (2) + 1) * (1) = 23
1,2,4,3 3,2,0 ((3 * (3) + 2) * (2) + 0) * (1) = 22
1,3,2,4 3,1,1 ((3 * (3) + 1) * (2) + 1) * (1) = 21
1,3,4,2 3,1,0 ((3 * (3) + 1) * (2) + 0) * (1) = 20
1,4,3,2 3,0,1 ((3 * (3) + 0) * (2) + 1) * (1) = 19
. . .
. . .
. . .
4,3,2,1 0,0,0 ((0 * (3) + 0) * (2) + 0) * (1) = 0
| | | | | |
| | | |
| |
上面的中間轉(zhuǎn)換指的是:每一個數(shù)字后面比當(dāng)前位數(shù)字大的數(shù)字的個數(shù)。比如:
1,3,4,2 中,1 后面有(3, 4, 2) 他們都大于1,所以第一位是 3
3 后面有(4, 2), 但只有4大于3,所以第二位是 1
4 后面有(2), 沒有比4 大的,所以第三位是 0
最后一位后面肯定沒有更大的,所以省略了一個0。
經(jīng)過這種轉(zhuǎn)換以后,就得到了一種表示方式(中間轉(zhuǎn)換),這種表達方式和原排列一一對應(yīng),可以相互轉(zhuǎn)化。
仔細觀察這種中間表達方式,發(fā)現(xiàn)它的第一位只能是(0,1,2,3),第二位只能是(0,1,2),第三位只能是(0,1)。通常,數(shù)字是用十進制表示的,計算機中用二進制,但是現(xiàn)在,我用一種特殊的進制來表示數(shù):
第一位用1進制,第二位用2進制,第三位用3進制
于是就得到了這種中間表示方式的十進制值。如:
階
| | |
1,1,0 ----> ((1 * (3) + 1) * (2) + 0) * (1) = 83,1,0 ----> ((3 * (3) + 1) * (2) + 0) * (1) = 20
這樣,就可以得到一個十進制數(shù)和一個排列之間的一一對應(yīng)的關(guān)系。
現(xiàn)在排列數(shù)和有序的十進制數(shù)有了一一對應(yīng)的關(guān)系(通過改變對應(yīng)關(guān)系,可以使十進制數(shù)升序)。
分享標題:STL next_permutation分析
網(wǎng)站地址:http://weahome.cn/article/joceip.html