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

隨筆 - 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 閱讀(2321) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国语自产在线不卡| 国产精品久久久久久久久久免费看 | 欧美一区二区在线视频| 亚洲视频播放| 国产日本欧美一区二区三区| 亚洲一区二区在线看| 亚洲无毛电影| 国产一区二区三区高清播放| 久久亚洲色图| 欧美日韩国产小视频| 午夜精品久久久久久久99水蜜桃 | 欧美精品在线极品| 欧美制服丝袜第一页| 欧美91大片| 欧美一区二区三区免费视频| 久久婷婷国产综合国色天香| 国产精品久久久久久久久借妻| 国产在线精品成人一区二区三区| 欧美大片在线看免费观看| 国产精品久久久久7777婷婷| 久久视频在线免费观看| 欧美日韩成人一区二区| 欧美波霸影院| 国产日韩欧美制服另类| 一区二区欧美亚洲| ●精品国产综合乱码久久久久 | 久久米奇亚洲| 国产婷婷精品| 久久国产福利| 国产精品久久久久毛片大屁完整版| 久久久久久综合网天天| 午夜精品免费在线| 久久精品夜色噜噜亚洲a∨| 欧美日韩精品在线| 亚洲精品一区二区在线| 日韩亚洲在线| 国产精品久线观看视频| 亚洲伊人第一页| 久久久噜噜噜久久中文字免| 国产精品hd| 久久久久久久波多野高潮日日| 午夜精品在线视频| 国产欧亚日韩视频| 嫩草伊人久久精品少妇av杨幂| 欧美激情aⅴ一区二区三区| 99re8这里有精品热视频免费| 欧美激情在线| 亚洲欧美日韩精品在线| 久久久五月婷婷| 日韩一级片网址| 国精产品99永久一区一区| 欧美成人蜜桃| 亚洲免费网址| 你懂的成人av| 午夜视频一区在线观看| **性色生活片久久毛片| 欧美系列电影免费观看| 老牛嫩草一区二区三区日本| 亚洲美女性视频| 欧美第一黄色网| 久久九九精品99国产精品| 在线视频日韩精品| 亚洲三级国产| 亚洲国产精品久久久久秋霞影院 | 久久久久国产精品午夜一区| 亚洲人成77777在线观看网| 亚洲女人小视频在线观看| 亚洲成色777777在线观看影院| 日韩午夜免费视频| 亚洲精品亚洲人成人网| 在线播放视频一区| 今天的高清视频免费播放成人| 国产日韩视频| 国产一区在线播放| 亚洲国产精品一区二区www| 国产一区二区三区黄视频| 国产在线拍偷自揄拍精品| 国产精品入口尤物| 国产综合自拍| 狠狠入ady亚洲精品经典电影| 黄网站免费久久| 亚洲国产精品免费| 99国产欧美久久久精品| 亚洲视频每日更新| 亚洲欧美日韩系列| 久久精品视频在线播放| 欧美国产在线视频| 最新成人av在线| 亚洲亚洲精品三区日韩精品在线视频| 亚洲午夜国产成人av电影男同| 亚洲午夜精品视频| 麻豆精品视频在线观看| 欧美激情一区在线| 国产自产女人91一区在线观看| 国产综合网站| 亚洲天堂av图片| 久久久综合香蕉尹人综合网| 亚洲乱码国产乱码精品精天堂| 亚洲午夜在线观看视频在线| 亚洲欧美日本国产专区一区| 亚洲免费观看视频| 久久久99国产精品免费| 欧美电影电视剧在线观看| 亚洲精品乱码久久久久久黑人| 一本色道久久88亚洲综合88| 亚洲制服丝袜在线| 美女在线一区二区| 国内精品嫩模av私拍在线观看| 亚洲欧美国产三级| 欧美韩日亚洲| 91久久综合亚洲鲁鲁五月天| 久久精彩视频| 午夜视频一区在线观看| 欧美日韩国产成人精品| 亚洲日韩中文字幕在线播放| 免费成人av| 久久久久久久久久久久久女国产乱| 国产精品vvv| 中日韩高清电影网| 日韩亚洲在线| 国产精品v欧美精品v日韩| 欧美精品少妇一区二区三区| 亚洲欧洲日产国产综合网| 欧美 日韩 国产精品免费观看| 新片速递亚洲合集欧美合集| 国产婷婷成人久久av免费高清| 久久国产精品免费一区| 久久免费99精品久久久久久| 国产自产精品| 亚洲电影一级黄| 欧美日韩成人精品| 久久精品主播| 农村妇女精品| 亚洲女同同性videoxma| 久久国产欧美日韩精品| 日韩亚洲欧美成人一区| 亚洲欧美日韩在线不卡| 亚洲国产精品高清久久久| 亚洲精品综合精品自拍| 在线观看中文字幕不卡| 日韩视频永久免费| 激情小说另类小说亚洲欧美| 欧美成人69av| 久久精品国产第一区二区三区最新章节| 鲁大师成人一区二区三区| 国产精品久线观看视频| 欧美高清在线一区| 欧美专区18| 亚洲欧美日韩中文视频| 另类天堂av| 久久人人爽国产| 欧美一区1区三区3区公司| 欧美日本在线看| 狠狠色丁香久久综合频道| 亚洲人成77777在线观看网| 国产一区二区欧美| 亚洲精品国产精品国自产观看浪潮| 国产亚洲欧美另类一区二区三区| 99在线精品观看| 亚洲经典在线看| 欧美成人四级电影| 亚洲国产精品999| 99国产精品国产精品毛片| 亚洲性视频网站| 亚洲美女毛片| 久久不见久久见免费视频1| 中国亚洲黄色| 久久福利影视| 久久精品中文| 激情综合激情| 理论片一区二区在线| 欧美成人精品1314www| 亚洲激情视频在线播放| 欧美日韩国产成人精品| 日韩视频在线永久播放| 亚洲欧美日韩一区在线| 国产婷婷色综合av蜜臀av| 久久青青草原一区二区| 亚洲国产一区二区三区青草影视 | 国产亚洲欧美日韩一区二区| 欧美一级久久久| 欧美大片在线看| 欧美在线视频免费观看| 国产亚洲欧洲一区高清在线观看| 久久久久国产一区二区三区四区| 91久久精品一区二区别| 午夜亚洲性色福利视频| 国产精品天美传媒入口| 欧美成人四级电影| 久久一二三四| 亚洲香蕉网站| 一本色道婷婷久久欧美| 亚洲电影欧美电影有声小说| 久久精品30| 久久久亚洲国产天美传媒修理工 | 亚洲经典自拍| 久久夜色撩人精品| 久久av老司机精品网站导航 | 亚洲视频视频在线| 亚洲欧洲三级|