青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 51, 文章 - 1, 評論 - 41, 引用 - 0
數據加載中……

從集合中枚舉子集

在很多算法中需要從一個集合中枚舉可能的子集特別在一些窮舉算法中,需要枚舉每種可能的子集,從而計算出最優解。本文將討論一種把子集映射N進制數字的枚舉方法。

從集合中枚舉子集有許多種情況。這里集合是指廣義的,它可能包含相同的元素。先討論不含相同元素的集合,枚舉問題規定如下:從N個元素的集合中,取出R的元素子集。根據子集的不同性質可分為:

子集是否可以重復包含某元素

子集的元素是否有序。

上面兩種情況自由組合可分為4種情形,見下表:

條件一

條件二


可以重復包含

有序

1

無序

2

不可重復包含

有序

3

無序

4

表一

1:按照這4種情況,枚舉集合{abc},其中R=2

情況1:有{aa}{ab}{ac}{ba}{bb}{bc}{ca}{cb}{cc}9種。

情況2:有{aa}{bb}{cc}{ab}{ac}{ba}6種。

情況3:有{ab}{ac}{ba}{bc}{ca}{cb}6種。

情況4:有{ab}{ac}{ba}3種。

下面討集合包含相同元素,這里的相同元素視為完全等同,可以替換。這樣集合含有兩個信息,一是含有N各不同的元素,二是每種元素有多少個。如果每種元素的個數為1,就是上面討論的情況。這里增加了新的討論條件,子集重復包含某元素的個數是否可以超過集合中該元素的個數。上一種情況,重復包含就意味超過。而在這里,就要分情況處理。

可以重復包含,可以超過

有序

1

無序

2

不可重復包含

有序

3

無序

4

可以重復包含,不可以超

有序

5

無序

6

表二

2:按照這6種情況,枚舉集合{aabc},其中R=2

情況1:有{aa}{ab}{ac}{ba}{bb}{bc}{ca}{cb}{cc}9種。

情況2:有{aa}{bb}{cc}{ab}{ac}{ba}6種。

情況3:有{ab}{ac}{ba}{bc}{ca}{cb}6種。

情況4:有{ab}{ac}{ba}3種。

情況5:有{aa}{ab}{ac}{ba}{bc}{ca}{cb}7種。

情況6:有{aa}{ab}{ac}{ba}4種。

比較例1和例2發現情況1234結果一樣,其實在可以超過的條件下,集合某個元素的個數是不起限制作用,結果也就一樣。所以可合并這兩種情況。從分析中知道,枚舉這樣的集合需要知道兩類信息。N種不同的元素和每種元素個數。N種不同的元素可以映射到0至(N-1N整數上。問題就變成了枚舉N個整數。枚舉出來的數字可以映射到原先的元素。N和表示每種元素個數的數組就是需要的信息。

// 構造函數
// 輸入參數:max表示集合元素的個數
// 輸入參賽:ele_num 表示第i個元素的個數
CSetIter::CSetIter(unsigned 
long max, const std::vector<int>& ele_num) :
    m_ele_num(ele_num)
{
    assert(max 
== ele_num.size());
    m_max 
= max;
}


枚舉
R個元素就是取R個數,每個數的取值0至(N-1。這樣每個子集對應一個RN進制的數。于是枚舉數0到NR-1就枚舉出每種可能的子集,然后判斷子集是否滿足條件。

// 得到下一個子集合
// 輸出參數:subset得到的子集合
// 返回值:1表示成功取得,0表示沒有取得,枚舉完畢
int CSetIter::GetNextSubset(std::vector<int>& subset)
{

    assert(subset.size() 
== m_size);
    
while (m_iter_num < m_iter_max)
    {
        
// 判斷是否符合條件
        
if ((this->*m_pfnIsSubsetOk)(m_iter_v))
        {
            subset 
= m_iter_v;
            IncIterNum();
            return 
1;
        }
        IncIterNum();
    }
    return 
0;
}


下面分別討論這六種情況如何判斷。

情況1:每個枚舉數都滿足要求。

// 子集合是否滿足可重復,有序條件
// 輸出參數:subset得到的子集合
// 返回值:1表示符合,0表示不符合
int CSetIter::IsMultOrdered(std::vector<int>& subset)
{
    return 
1;
}


情況
2:枚舉數高位的數字不大于低位的數字。

// 子集合是否滿足可重復,無序條件
// 輸出參數:subset得到的子集合
// 返回值:1表示符合,0表示不符合
int CSetIter::IsMultDisorder(std::vector<int>& subset)
{
    
for (int i=0; i<m_size-1; i++)
    {
        
if (subset[i] > subset[i+1])
            return 
0;
    }
    return 
1;
}


情況
3枚舉數的各位數字不能相同。

// 子集合是否滿足不重復,有序條件
// 輸出參數:subset得到的子集合
// 返回值:1表示符合,0表示不符合
int CSetIter::IsSingleOrdered(std::vector<int>& subset)
{
    
for (int i=0; i<m_size-1; i++)
    {
        
for (int j=i+1; j<m_size; j++)
        {
            
if (subset[i] == subset[j])
                return 
0;
        }
    }
    return 
1;
}


情況4:枚舉數高位的數字小于低位的數字。

// 子集合是否滿足不重復,無序條件
// 輸出參數:subset得到的子集合
// 返回值:1表示符合,0表示不符
int CSetIter::IsSingleDisorder(std::vector<int>& subset)
{
    
for (int i=0; i<m_size-1; i++)
    {
        
if (subset[i] >= subset[i+1])
            return 
0;
    }
    return 
1;
}


情況
5數字在枚舉數出現的次數不能超過該數字對應元素的個數。

// 子集元素重復,有序,不能超出集合
// 輸出參數:subset得到的子集合
// 返回值:1表示符合,0表示不符
int CSetIter::IsMultOrderedIn(std::vector<int>& subset)
{
    std::vector
<int> tmp(m_ele_num.size(), 0);
    
for (int i=0; i<m_size; i++)
    {
        tmp[subset[i]]
++;
        
if (tmp[subset[i]] > m_ele_num[subset[i]])
            return 
0;
    }
    return 
1;
}


情況
6情況5加上情況2

// 子集元素重復,無序,不能超出集合
// 輸出參數:subset得到的子集合
// 返回值:1表示符合,0表示不符
int CSetIter::IsMultDisorderIn(std::vector<int>& subset)
{
    std::vector
<int> tmp(m_ele_num.size(), 0);
    
for (int i=0; i<m_size-1; i++)
    {
        
if (subset[i] > subset[i+1])
            return 
0;
    }
    
for (int i=0; i<m_size; i++)
    {
        tmp[subset[i]]
++;
        
if (tmp[subset[i]] > m_ele_num[subset[i]])
            return 
0;
    }
    return 
1;
}


其他實現見代碼

代碼編譯方式:

g++ SetIter.cpp -D_SETITER_TEST_ 編譯,運行。可看到例1的結果,

g++ SetIter.cpp -D_SETITERAGENT_TEST_ 編譯,運行,就可以看到例2的結果。
 

 

posted on 2007-11-03 12:36 lemene 閱讀(2335) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            香蕉成人久久| 亚洲黄色成人| 久久精品二区三区| 亚洲成色精品| 久久精品72免费观看| 欧美午夜精品一区二区三区| 亚洲国产精品成人综合色在线婷婷| 亚洲欧美激情一区二区| 亚洲人体偷拍| 欧美激情一区二区三区蜜桃视频| **网站欧美大片在线观看| 久久久999精品视频| 亚洲欧美日本国产有色| 国产精品v亚洲精品v日韩精品| av不卡在线看| 亚洲人体一区| 亚洲国产日韩美| 一区二区三区鲁丝不卡| 亚洲一级二级| 久久久xxx| 一区二区欧美在线观看| 久久精品国产99国产精品澳门| 9i看片成人免费高清| 亚洲午夜在线视频| 亚洲免费高清视频| 玖玖在线精品| 免费91麻豆精品国产自产在线观看| 欧美日韩成人综合天天影院| 亚洲第一精品福利| 伊人精品成人久久综合软件| 午夜精品久久久久久| 性欧美xxxx大乳国产app| 欧美日韩福利视频| 一本一本久久a久久精品综合麻豆| 亚洲三级观看| 欧美精品入口| 亚洲一区国产| 久久久久久久激情视频| 国产亚洲成av人片在线观看桃| 亚洲女人小视频在线观看| 午夜精品久久久久久久久久久久久| 欧美婷婷久久| 性高湖久久久久久久久| 欧美黄在线观看| 一区二区三区日韩| 国产午夜一区二区三区| 欧美精品激情在线| 午夜视频一区| 亚洲欧洲在线视频| 欧美影院成人| 亚洲伦理在线观看| 国产视频一区在线观看| 蜜桃av噜噜一区| 一区二区日韩伦理片| 国产一区白浆| 欧美日韩另类在线| 久久亚洲不卡| 欧美一区二区三区在| 日韩亚洲视频在线| 蜜臀av国产精品久久久久| 亚洲伦伦在线| 亚洲欧洲精品一区二区三区不卡| 欧美视频免费在线| 欧美成人精品在线视频| 久久精品30| 久久精品成人一区二区三区蜜臀| 亚洲国产精品一区二区尤物区| 久久频这里精品99香蕉| 欧美中文字幕在线观看| 亚洲影院在线观看| 亚洲综合导航| 欧美在线网址| 久久国产一二区| 久久人91精品久久久久久不卡| 亚洲一区二区三区色| 日韩午夜在线观看视频| 亚洲精品网站在线播放gif| 亚洲国产经典视频| 亚洲精品永久免费| 一区二区欧美亚洲| 欧美一区二区啪啪| 久久婷婷久久| 亚洲激情另类| 亚洲网站在线观看| 欧美一区二区国产| 欧美freesex交免费视频| 欧美福利在线观看| 欧美午夜视频| 一区二区亚洲欧洲国产日韩| 精品999久久久| 在线一区二区三区四区| 亚洲综合精品自拍| 玖玖精品视频| 亚洲中字在线| 久久综合网hezyo| 亚洲韩日在线| 久久久水蜜桃| 欧美亚洲第一区| 亚洲黄色在线看| 欧美在线一二三区| 9久草视频在线视频精品| 亚洲永久精品大片| 欧美日韩精品二区| 亚洲福利在线看| 久久久99爱| 亚洲欧美乱综合| 国产精品美女久久久免费| 亚洲欧洲另类| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产精品免费福利| 91久久亚洲| 男人天堂欧美日韩| 久久全国免费视频| 国产日韩欧美a| 欧美自拍丝袜亚洲| 亚洲欧美日本在线| 国产日韩综合| 久久精品国产精品亚洲精品| 亚洲一级在线| 国产亚洲精品久久久久动| 欧美在线三级| 久久国产综合精品| 亚洲人人精品| 亚洲婷婷在线| 国内精品模特av私拍在线观看| 欧美在线亚洲在线| 久久色在线播放| 亚洲精品久久嫩草网站秘色| 亚洲精品一级| 国产永久精品大片wwwapp| 农村妇女精品| 91久久在线播放| 国产麻豆精品视频| 欧美激情一区二区三级高清视频 | 久久九九免费| 日韩视频一区二区三区| 亚洲中午字幕| 亚洲精品久久| 欧美一区二区视频在线| 99国产一区| 久久人人九九| 欧美在线观看视频| 欧美日韩亚洲综合一区| 欧美福利在线| 国产一区二区黄色| 亚洲视频免费观看| 99视频国产精品免费观看| 欧美一区二区三区视频在线| 亚洲小说欧美另类婷婷| 欧美a级在线| 欧美黄色成人网| 黄色av日韩| 久久久久久亚洲精品中文字幕| 在线观看福利一区| 久久精品国产77777蜜臀| 久久国产精品99久久久久久老狼| 欧美激情一区二区三区四区| 欧美性色综合| 欧美一区二区三区在线视频| av成人毛片| 韩日欧美一区二区| 欧美成人在线免费观看| 欧美电影免费观看大全| 亚洲精品免费一二三区| 美女性感视频久久久| 久久久久国产一区二区| 国产精品综合久久久| 亚洲国产mv| 久久久久久久精| 欧美在线日韩| 尤物在线观看一区| 日韩视频专区| 欧美亚韩一区| 欧美大片专区| 亚洲在线日韩| 久久久久久综合| 久久精品久久综合| 你懂的视频一区二区| 亚洲主播在线观看| 欧美精品在线观看一区二区| 亚洲国产一区二区视频| 亚洲美女精品成人在线视频| 欧美日韩国产在线看| 欧美亚洲在线| 欧美激情第一页xxx| 91久久极品少妇xxxxⅹ软件| 欧美激情自拍| 香蕉久久一区二区不卡无毒影院| 欧美激情影院| 久久国产精品第一页| 99re热这里只有精品免费视频| 国产九九精品视频| 欧美私人网站| 欧美电影免费观看高清完整版| 午夜激情综合网| 亚洲性视频网址| 亚洲国产网站| 欧美福利视频网站| 欧美va亚洲va日韩∨a综合色| 久久精品免费观看|