在標(biāo)準(zhǔn)庫算法中,next_permutation可以計(jì)算一組數(shù)據(jù)的全排列,下面是簡(jiǎn)單的剖析
創(chuàng)新互聯(lián),為您提供成都網(wǎng)站建設(shè)公司、成都網(wǎng)站制作、網(wǎng)站營(yíng)銷推廣、網(wǎng)站開發(fā)設(shè)計(jì),對(duì)服務(wù)咖啡廳設(shè)計(jì)等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)及推廣經(jīng)驗(yàn)。創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司成立于2013年,提供專業(yè)網(wǎng)站制作報(bào)價(jià)服務(wù),我們深知市場(chǎng)的競(jìng)爭(zhēng)激烈,認(rèn)真對(duì)待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進(jìn)步,是我們永遠(yuǎn)的責(zé)任!首先查看STL中函數(shù)原型:
template <class BidirectionalIterator> bool next_permutation (BidirectionalIterator first, BidirectionalIterator last ); template <class BidirectionalIterator, class Compare> bool next_permutation (BidirectionalIterator first, BidirectionalIterator last, Compare comp);
兩個(gè)重載函數(shù)。第二個(gè)帶謂詞參數(shù)comp,默認(rèn)謂詞函數(shù)為“”
下面為一個(gè)例子:
#include <iostream> #include <algorithm> using namespace std; typedef bool (*COMP)(int,int); bool Compare(int a,int b) { return !(a<b); } int main() { int a[] = {3,1,2}; COMP comp=Compare; do{ cout << a[0] << " " << a[1] << " " << a[2] << endl; }while (next_permutation(a,a+3,comp)); return 0; }
運(yùn)行結(jié)果:
下圖是在Linux下stl_algo.h中next_permutation的部分代碼:
如果要比較的數(shù)列中只有一個(gè)元素的話返回直接false;否則使變量__i指數(shù)列的最后一個(gè)元素,進(jìn)入循環(huán) ;
從最右邊邊開始比較倆個(gè)相鄰的元素,直到找到左邊比右邊小的那兩個(gè)數(shù),左邊那個(gè)就是待交換的數(shù)
再?gòu)淖钣疫呴_始,找比代替換的那個(gè)數(shù)大的第一個(gè)元素,然后交換這兩個(gè)數(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)換指的是:每一個(gè)數(shù)字后面比當(dāng)前位數(shù)字大的數(shù)字的個(gè)數(shù)。比如:
1,3,4,2 中,1 后面有(3, 4, 2) 他們都大于1,所以第一位是 3
3 后面有(4, 2), 但只有4大于3,所以第二位是 1
4 后面有(2), 沒有比4 大的,所以第三位是 0
最后一位后面肯定沒有更大的,所以省略了一個(gè)0。
經(jīng)過這種轉(zhuǎn)換以后,就得到了一種表示方式(中間轉(zhuǎn)換),這種表達(dá)方式和原排列一一對(duì)應(yīng),可以相互轉(zhuǎn)化。
仔細(xì)觀察這種中間表達(dá)方式,發(fā)現(xiàn)它的第一位只能是(0,1,2,3),第二位只能是(0,1,2),第三位只能是(0,1)。通常,數(shù)字是用十進(jìn)制表示的,計(jì)算機(jī)中用二進(jìn)制,但是現(xiàn)在,我用一種特殊的進(jìn)制來表示數(shù):
第一位用1進(jìn)制,第二位用2進(jìn)制,第三位用3進(jìn)制
于是就得到了這種中間表示方式的十進(jìn)制值。如:
階
| | |
1,1,0 ----> ((1 * (3) + 1) * (2) + 0) * (1) = 8
3,1,0 ----> ((3 * (3) + 1) * (2) + 0) * (1) = 20
這樣,就可以得到一個(gè)十進(jìn)制數(shù)和一個(gè)排列之間的一一對(duì)應(yīng)的關(guān)系。
現(xiàn)在排列數(shù)和有序的十進(jìn)制數(shù)有了一一對(duì)應(yīng)的關(guān)系(通過改變對(duì)應(yīng)關(guān)系,可以使十進(jìn)制數(shù)升序)。
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開啟,新人活動(dòng)云服務(wù)器買多久送多久。
網(wǎng)站題目:STLnext_permutation分析-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://jinyejixie.com/article18/egedp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、域名注冊(cè)、面包屑導(dǎo)航、外貿(mào)建站、網(wǎng)站內(nèi)鏈、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)