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

隨筆 - 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>
            欧美一级专区| 性娇小13――14欧美| 欧美精品在线观看播放| 久久精品在这里| 欧美怡红院视频一区二区三区| 亚洲精品影院| 一区二区日本视频| 亚洲视频在线观看网站| 亚洲免费在线观看| 欧美一级艳片视频免费观看| 久久久www成人免费精品| 久久久久国产一区二区三区四区| 欧美一级电影久久| 米奇777超碰欧美日韩亚洲| 欧美女激情福利| 国产美女在线精品免费观看| 狠狠噜噜久久| 日韩亚洲欧美高清| 久久精品盗摄| 久久亚洲欧美国产精品乐播| 欧美成人免费在线视频| 99精品欧美一区二区三区综合在线| 中文精品视频| 久久在线免费观看| 欧美午夜电影在线观看| 国产区二精品视| 久久色中文字幕| 麻豆精品精品国产自在97香蕉| 欧美日本簧片| 激情成人在线视频| 亚洲一区精品电影| 欧美 日韩 国产精品免费观看| 91久久久久久久久| 欧美在线免费观看亚洲| 亚洲人成在线观看一区二区| 国产精品99久久99久久久二8 | 99视频一区二区| 午夜精品久久久久久久久久久久久| 老司机午夜精品视频| 日韩亚洲不卡在线| 久久人人爽国产| 国产精品一二| av成人老司机| 亚洲成色777777女色窝| 香蕉久久久久久久av网站| 欧美日韩国产三级| 亚洲高清三级视频| 久久一区中文字幕| 午夜精品久久久久久久久久久久久 | 亚洲欧美日韩国产精品| 亚洲国产成人91精品| 久久久精品国产99久久精品芒果| 欧美日韩国产综合一区二区| 亚洲国产精品福利| 另类av一区二区| 久久av一区二区三区漫画| 国产精品日韩高清| 亚洲一区二区动漫| 一区二区三区|亚洲午夜| 欧美精品福利在线| 一本色道久久加勒比88综合| 亚洲青色在线| 欧美日韩中国免费专区在线看| 亚洲精品日韩精品| 亚洲经典三级| 欧美高清视频一区二区三区在线观看| 久久综合给合| 一道本一区二区| 亚洲精品国产品国语在线app| 欧美大片专区| 一本色道88久久加勒比精品| 亚洲欧洲一区| 欧美性猛交xxxx乱大交蜜桃 | 亚洲图片欧美一区| 亚洲欧洲一区二区三区久久| 欧美成人性生活| 亚洲精品在线视频观看| 亚洲三级毛片| 欧美色网在线| 欧美一区午夜精品| 久久久国产精品一区二区中文| 在线观看日产精品| 亚洲三级免费电影| 国产香蕉久久精品综合网| 免费观看亚洲视频大全| 欧美激情精品久久久久久免费印度 | 久久综合久久88| 日韩西西人体444www| 一本色道久久综合一区| 国产欧美日韩亚洲| 每日更新成人在线视频| 欧美国产免费| 欧美在线电影| 免费h精品视频在线播放| 亚洲视频网站在线观看| 久久成人亚洲| 亚洲精品久久久久中文字幕欢迎你| 亚洲欧洲精品一区二区三区波多野1战4 | 国产精品免费一区二区三区在线观看| 先锋影音网一区二区| 久久久久国产免费免费| 亚洲激情电影在线| a91a精品视频在线观看| 亚洲午夜在线观看视频在线| 在线精品高清中文字幕| 一区二区三区成人| 亚洲激情成人| 久久国产精品99国产| 一本色道久久88综合日韩精品| 欧美中文字幕视频在线观看| 在线亚洲精品| 牛牛影视久久网| 久久精品国产欧美亚洲人人爽| 欧美精品久久久久a| 裸体素人女欧美日韩| 国产精品久久久久久久午夜片| 亚洲电影免费观看高清| 国产亚洲福利| 亚洲一区二区三区午夜| 一本久久知道综合久久| 久热爱精品视频线路一| 久久精品二区| 国产欧亚日韩视频| 亚洲一二三级电影| 亚洲天堂男人| 欧美日韩八区| 亚洲一区二区高清| 久久经典综合| 欧美在线视屏| 欧美视频在线一区二区三区| 欧美激情bt| 亚洲欧美一区二区视频| 欧美在线视频一区二区| 欧美精品aa| 女仆av观看一区| 国内精品久久久久影院色| 亚洲一区二区免费看| 亚洲欧洲99久久| 欧美视频中文在线看| 99在线精品视频| 亚洲欧美福利一区二区| 国产精品网站在线观看| 午夜欧美视频| 久久亚洲一区二区三区四区| 国产一区二区看久久| 欧美夜福利tv在线| 久久综合伊人| 在线日韩成人| 久久综合伊人77777尤物| 伊人天天综合| 一区二区三区欧美激情| 欧美在线在线| 久久电影一区| 国产有码在线一区二区视频| 香蕉视频成人在线观看| 久久久久久夜精品精品免费| 国产亚洲一区二区三区在线观看| 亚洲一区精品视频| 久久久福利视频| 亚洲高清影视| 欧美日本中文字幕| 亚洲一区二区三区四区中文 | 亚洲欧美激情四射在线日 | 国内精品久久久| 久久免费的精品国产v∧| 欧美激情第8页| 亚洲伊人观看| 国内精品美女av在线播放| 免费看av成人| 亚洲一区欧美一区| 免费成人高清视频| 亚洲天堂成人在线视频| 国产综合精品| 欧美日韩视频在线第一区| 欧美亚洲一区在线| 亚洲免费av片| 蜜臀a∨国产成人精品| 日韩视频一区二区在线观看| 国产麻豆9l精品三级站| 麻豆久久精品| 欧美一区二区三区在| 91久久久久| 欧美在线三级| 一本一道久久综合狠狠老精东影业| 国产日韩一区二区三区| 亚洲欧美在线aaa| 亚洲二区三区四区| 国产精品一区免费在线观看| 欧美jizz19hd性欧美| 亚洲欧美日韩中文视频| 最新成人av在线| 久久综合狠狠| 午夜欧美大尺度福利影院在线看| 两个人的视频www国产精品| 欧美一级久久久| 99精品视频免费观看| 亚洲国产成人久久综合| 久久综合久久久| 亚洲香蕉在线观看| 日韩亚洲国产欧美|