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

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

從集合中枚舉子集

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

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

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

,子集的元素是否有序。

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

條件一

條件二


可以重復包含

有序

1

無序

2

不可重復包含

有序

3

無序

4

表一

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

情況1:有{a,a},{a,b},{a,c},{ba},{b,b},{bc},{c,a},{c,b},{c,c}9種。

情況2:有{a,a}{b,b},{c,c},{ab},{a,c}{ba}6種。

情況3:有{a,b},{a,c},{b,a},{b,c}{c,a},{cb}6種。

情況4:有{a,b}{a,c},{b,a}3種。

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

可以重復包含,可以超過

有序

1

無序

2

不可重復包含

有序

3

無序

4

可以重復包含,不可以超

有序

5

無序

6

表二

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

情況1:有{aa}{a,b},{ac},{b,a},{b,b},{b,c},{c,a},{c,b}{c,c}9種。

情況2:有{aa},{b,b},{c,c},{a,b},{ac},{ba}6種。

情況3:有{a,b},{a,c},{b,a},{b,c}{c,a},{cb}6種。

情況4:有{a,b},{a,c}{b,a}3種。

情況5:有{a,a}{a,b},{a,c}{b,a},{b,c},{ca},{c,b}7種。

情況6:有{a,a},{a,b},{a,c},{ba}4種。

比較例1和例2發現情況1,2,3,4結果一樣,其實在可以超過的條件下,集合某個元素的個數是不起限制作用,結果也就一樣。所以可合并這兩種情況。從分析中知道,枚舉這樣的集合需要知道兩類信息。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_ 編譯,運行??煽吹嚼?/font>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>
            久久精品成人一区二区三区| 欧美成人精品一区二区| 日韩午夜激情av| 国产精品v欧美精品v日韩| 久久香蕉国产线看观看网| 欧美日韩精品一区二区| 另类激情亚洲| 国产精品爽爽爽| 9色精品在线| 日韩一级网站| 蜜臀av国产精品久久久久| 久久精品亚洲国产奇米99| 欧美亚男人的天堂| 亚洲精品日韩久久| 亚洲看片一区| 欧美韩国在线| 亚洲三级视频在线观看| 亚洲国产毛片完整版 | 欧美区一区二区三区| 久久爱www久久做| 国产一区二区三区在线观看免费| 9色精品在线| 一区二区91| 欧美日韩在线免费| 一区二区三区欧美成人| 亚洲欧美大片| 伊人久久综合| 欧美日韩亚洲一区二区三区在线 | 久久久久免费观看| 一本色道久久综合亚洲二区三区| 亚洲清纯自拍| 国产精品久久久久毛片大屁完整版 | 亚洲丁香婷深爱综合| 麻豆成人精品| 99re6这里只有精品| 欧美在线观看网址综合| 伊人成综合网伊人222| 欧美久久久久久久| 午夜亚洲精品| 亚洲国产精品一区二区尤物区| 亚洲欧美精品中文字幕在线| 国产真实乱子伦精品视频| 欧美~级网站不卡| 欧美伊人久久久久久午夜久久久久 | 亚洲视频你懂的| 国产日本欧洲亚洲| 欧美日韩一二三四五区| 女人色偷偷aa久久天堂| 亚洲九九爱视频| 99国产麻豆精品| 136国产福利精品导航网址| 欧美体内谢she精2性欧美| 久久婷婷国产综合尤物精品 | 亚洲国产精品美女| 国内精品福利| 欧美第一黄色网| 美玉足脚交一区二区三区图片| 久久精品人人| 久久国产精品久久久久久电车| 亚洲乱码精品一二三四区日韩在线 | 中国成人黄色视屏| 亚洲免费观看高清完整版在线观看熊 | 亚洲一区二区三区在线观看视频| 亚洲国产欧美日韩| 亚洲国产老妈| 亚洲影视在线| 久久久久久电影| 亚洲综合精品四区| 欧美一区二区播放| 久久婷婷国产综合精品青草| 欧美18av| 欧美美女bbbb| 欧美jizz19hd性欧美| 欧美久久久久久久久| 欧美国产日本| 国产美女精品视频免费观看| 国产精品久久久久久五月尺| 国产精品精品视频| 欧美高清在线| 日韩亚洲视频| 欧美国产1区2区| 亚洲午夜国产成人av电影男同| 久久久免费精品视频| 国产精品美女www爽爽爽| 久久精品视频99| 欧美性视频网站| 中文日韩电影网站| 亚洲精品国产视频| 欧美华人在线视频| 洋洋av久久久久久久一区| 亚洲激情在线观看| 欧美高清在线一区二区| 亚洲成色777777女色窝| 老司机午夜精品视频在线观看| 午夜精品久久久久久久99樱桃| 国产精品xxx在线观看www| 亚洲欧美日韩在线不卡| 亚洲视频精品| 在线观看av不卡| 亚洲电影成人| 国产精品久久久久影院色老大 | 国产精品一区二区三区免费观看 | 亚洲一区二区三区中文字幕在线 | 久久精品中文| 伊人久久综合| 亚洲桃色在线一区| 国产一在线精品一区在线观看| 欧美 日韩 国产精品免费观看| 美女被久久久| 亚洲女女女同性video| 久久精品日韩| 亚洲免费伊人电影在线观看av| 性久久久久久久久| 一区二区三区日韩在线观看| 一区二区三区欧美成人| 久久精品国产亚洲5555| 一级成人国产| 久久中文精品| 久久久久久久一区二区三区| 欧美一区二区视频在线观看| 亚洲一区视频在线观看视频| 尤物九九久久国产精品的特点 | 亚洲线精品一区二区三区八戒| 午夜激情综合网| 在线视频精品一区| 欧美不卡在线| 欧美成人精品高清在线播放| 国产精品久久久久一区二区三区共 | 亚洲看片网站| 久久综合伊人77777麻豆| 久久国产精品毛片| 国产精品毛片一区二区三区| 亚洲美女在线观看| 中文在线一区| 欧美日本亚洲韩国国产| 99av国产精品欲麻豆| 一本综合久久| 欧美精品大片| 一区二区高清视频| 亚洲尤物在线视频观看| 欧美午夜理伦三级在线观看| 亚洲精品小视频| 亚洲女优在线| 国产日韩成人精品| 久久国产精品久久久久久| 久久只有精品| 91久久在线播放| 欧美视频不卡中文| 久久成人免费视频| 久久丁香综合五月国产三级网站| 久久成人18免费网站| 亚洲夫妻自拍| 国产欧美日韩三级| 免费成人在线观看视频| 亚洲精品三级| 久久久精品一区二区三区| 最近中文字幕日韩精品 | 国产精品日日摸夜夜摸av| 久久国产精品亚洲va麻豆| 欧美国产另类| 欧美影视一区| 亚洲视频日本| 狠狠色综合一区二区| 欧美激情视频在线免费观看 欧美视频免费一 | 国内精品久久久久久影视8| 欧美高清视频www夜色资源网| 亚洲影院污污.| 亚洲国产日韩欧美在线图片| 亚洲欧美在线免费| 日韩一级片网址| 永久免费视频成人| 国产丝袜一区二区三区| 国产精品久久久久一区二区| 欧美精品啪啪| 欧美精品久久天天躁| 欧美成年人视频| 欧美成人一品| 欧美精品亚洲精品| 欧美精品福利在线| 欧美日韩免费精品| 欧美视频日韩| 国产精品自拍三区| 国产午夜精品视频免费不卡69堂| 国产精品一区二区视频| 欧美性片在线观看| 国产精品资源| 亚洲国产精选| 久久尤物视频| 欧美日韩国产一级片| 欧美三日本三级少妇三2023| 国产精品xvideos88| 国产主播一区二区三区| 有码中文亚洲精品| 91久久黄色| 亚洲欧美精品| 免费欧美在线| 蜜臀久久99精品久久久久久9| 欧美偷拍另类| 亚洲一区久久| 日韩一区二区久久|