欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

STLnext_permutation分析-創(chuàng)新互聯(lián)

在標準庫算法中,next_permutation可以計算一組數(shù)據(jù)的全排列,下面是簡單的剖析

創(chuàng)新互聯(lián),為您提供成都網(wǎng)站建設公司、成都網(wǎng)站制作、網(wǎng)站營銷推廣、網(wǎng)站開發(fā)設計,對服務咖啡廳設計等多個行業(yè)擁有豐富的網(wǎng)站建設及推廣經(jīng)驗。創(chuàng)新互聯(lián)網(wǎng)站建設公司成立于2013年,提供專業(yè)網(wǎng)站制作報價服務,我們深知市場的競爭激烈,認真對待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進步,是我們永遠的責任!

首先查看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);

兩個重載函數(shù)。第二個帶謂詞參數(shù)comp,默認謂詞函數(shù)為“”

下面為一個例子:

#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;
}

運行結(jié)果:

STL      next_permutation分析

下圖是在Linux下stl_algo.h中next_permutation的部分代碼:

STL      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ù)字后面比當前位數(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)換),這種表達方式和原排列一一對應,可以相互轉(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) = 8

3,1,0    ---->   ((3 * (3) + 1) * (2) + 0) * (1) = 20

這樣,就可以得到一個十進制數(shù)和一個排列之間的一一對應的關系。
現(xiàn)在排列數(shù)和有序的十進制數(shù)有了一一對應的關系(通過改變對應關系,可以使十進制數(shù)升序)。

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡助力業(yè)務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調(diào)度,確保服務器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務器買多久送多久。

網(wǎng)站題目:STLnext_permutation分析-創(chuàng)新互聯(lián)
標題鏈接:http://chinadenli.net/article18/egedp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作域名注冊、面包屑導航外貿(mào)建站、網(wǎng)站內(nèi)鏈做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網(wǎng)站建設