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

經典的狀態壓縮DP,《算法藝術與信息學競賽》的例題。f[i][j]表示前i行,最后兩行狀態為二進制數j,嵌入的最多芯片數。第i行到第i+1行用DFS進行狀態轉移。
由于第i+1行只和第i行有關,故可以用滾動數組優化。

/*************************************************************************
Author: WHU_GCC
Created Time: 2000-9-12 11:08:54
File Name: pku1038.cpp
Description: 
***********************************************************************
*/

#include 
<iostream>
using namespace std;

#define out(x) (cout << #x << ": " << x << endl)
typedef 
long long int64;
const int maxint = 0x7FFFFFFF;
const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;
template 
<class T> void show(T a, int n) for (int i = 0; i < n; ++i) cout << a[i] << ' '; cout << endl; }
template 
<class T> void show(T a, int r, int l) for (int i = 0; i < r; ++i) show(a[i], l); cout << endl; }

const int maxn = 150;
const int maxm = 10;

int n, m, k;
int g[maxn];

int cnt_mask;
int mask[30];

int f[2][1 << (2 * maxm)];

void generate_mask()
{
    cnt_mask 
= 0;
    
for (int i = 0; i < m - 2; i++)
    
{
        
int tmp = 0;
        tmp 
|= 7 << (2 * m + i);
        tmp 
|= 7 << (m + i);
        mask[cnt_mask
++= tmp;
        tmp 
= 0;
        tmp 
|= 7 << (m + i);
        tmp 
|= 7 << (i);
        mask[cnt_mask
++= tmp;
    }

    
for (int i = 0; i < m - 1; i++)
    
{
        
int tmp = 0;
        tmp 
|= 3 << (2 * m + i);
        tmp 
|= 3 << (m + i);
        tmp 
|= 3 << (i);
        mask[cnt_mask
++= tmp;
    }

}


void dfs(int row, int org_t, int now_t, int now, int cnt)
{
    f[(row 
+ 1% 2][now_t & ((1 << (2 * m)) - 1)] >?= f[row % 2][org_t] + cnt;
    
for (int i = now; i < cnt_mask; i++)
        
if ((now_t & mask[i]) == 0)
            dfs(row, org_t, now_t 
| mask[i], i + 1, cnt + 1);
}


int dp()
{
    memset(f, 
-1sizeof(f));
    f[
1][(g[0<< m) | g[1]] = 0;

    
int end = (1 << (2 * m));
    
for (int i = 1; i < n - 1; i++)
    
{
        
for (int j = 0; j < end; j++if (f[i % 2][j] != -1)
        
{
            
int t = (j << m) | g[i + 1];
            dfs(i, j, t, 
00);
        }

        memset(f[i 
% 2], -1sizeof(f[i % 2]));
    }

    
int ret = 0;
    
for (int i = 0; i < end; i++)
        ret 
>?= f[(n - 1% 2][i];
    
return ret;
}


int main()
{
    
int ca;
    
for (scanf("%d"&ca); ca--;)
    
{
        scanf(
"%d%d%d"&n, &m ,&k);
        memset(g, 
0sizeof(g));
        
for (int i = 0; i < k; i++)
        
{
            
int x, y;
            scanf(
"%d%d"&x, &y);
            g[x 
- 1|= 1 << (y - 1);
        }

        generate_mask();
        printf(
"%d\n", dp());
    }

    
return 0;
}
posted on 2007-09-12 20:44 Felicia 閱讀(1587) 評論(3)  編輯 收藏 引用 所屬分類: 動態規劃
Comments
  • # re: [動態規劃]pku1038
    Run&Run
    Posted @ 2007-11-21 15:41
    大牛同志,你的方法和<<算法藝術與信息學競賽上>>寫的不太一樣....
    狀態壓縮的DP......研究了我足足5個小時才看明白.....
    你開頭的解釋也太少了吧,光那個mask[]就想了我快兩個小時.
    你要照顧新人撒,多寫點解釋撒.
    話說回來,你位運算確實用得出神入化,佩服!  回復  更多評論   
  • # re: [動態規劃]pku1038
    Felicia
    Posted @ 2007-11-21 15:44
    mask表示所有可能的放置情況  回復  更多評論   
  • # re: [動態規劃]pku1038
    prister
    Posted @ 2016-05-18 01:05
    @Run&amp;Run
    里面的兩處>?=是什么意思  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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一区| 欧美一区二区啪啪| 久久在线精品| 欧美性色aⅴ视频一区日韩精品| 国产欧美精品va在线观看| 黄色亚洲精品| 艳妇臀荡乳欲伦亚洲一区| 午夜视频在线观看一区| 久久午夜色播影院免费高清| 亚洲精品日韩激情在线电影| 亚洲欧美在线免费| 欧美成人黑人xx视频免费观看| 欧美激情一区二区三区在线视频| 国产精品久久77777| 尤物九九久久国产精品的分类| 日韩图片一区| 裸体素人女欧美日韩| 一本色道久久综合亚洲精品高清| 亚洲成色777777在线观看影院| 亚洲永久视频| 亚洲国产影院| 欧美一级视频| 国产精品久久久久国产a级| 亚洲高清二区| 久久精品国产综合| 亚洲一品av免费观看| 欧美大学生性色视频| 精品91视频| 欧美亚洲自偷自偷| 亚洲精品一品区二品区三品区| 久久久久久久尹人综合网亚洲 | 欧美一级淫片播放口| 男人插女人欧美| 午夜免费电影一区在线观看| 欧美色欧美亚洲另类二区| 在线观看av一区| 久久精品国产第一区二区三区最新章节| 亚洲日本成人女熟在线观看| 久久久久se| 国产欧美日韩一区二区三区| 亚洲一区二区三区在线播放| 亚洲日本在线观看| 欧美电影免费网站| 亚洲第一级黄色片| 米奇777在线欧美播放| 欧美一区二区视频在线| 国产精品欧美日韩一区二区| 亚洲永久免费观看| 宅男在线国产精品| 国产精品久久久久三级| 亚洲午夜激情免费视频| 亚洲免费黄色| 欧美视频在线观看| 午夜精品在线视频| 午夜精品久久久久久久| 国内精品久久久久久| 久久综合久久综合久久综合| 久久久久久夜| 午夜在线精品| 国产精品婷婷| 久久久久国产精品午夜一区| 性欧美超级视频| 国产一区二区你懂的| 久久综合婷婷| 欧美大片在线看| 亚洲视频福利| 亚洲影院色无极综合| 韩国成人精品a∨在线观看| 久久亚洲综合色| 欧美成人免费网| 亚洲男人影院| 久久久www成人免费精品| 尤物九九久久国产精品的分类| 欧美激情91| 国产精品久久久久久久久久免费| 久久av免费一区| 亚洲高清自拍| 亚洲第一免费播放区| 欧美精品一区二区三区久久久竹菊| 日韩视频中文字幕| 亚洲视频在线播放| 国产亚洲激情在线| 亚洲国产国产亚洲一二三| 欧美日韩第一区日日骚| 久久电影一区| 麻豆亚洲精品| 性欧美超级视频| 裸体女人亚洲精品一区| 亚洲一区二三| 欧美v国产在线一区二区三区| 国产精品视频一二三| 老司机免费视频久久| 亚洲美女黄网| 黄色成人91| 亚洲综合导航| 亚洲精品视频在线观看网站| 亚洲欧美视频| 中文欧美字幕免费| 久久嫩草精品久久久久| 一区二区欧美在线| 久久综合伊人77777| 亚洲永久字幕| 欧美成人国产| 美女主播视频一区| 国产欧美日韩伦理| 日韩亚洲欧美成人一区| 又紧又大又爽精品一区二区| 一区二区三区不卡视频在线观看 | 国产精品人人爽人人做我的可爱| 美女脱光内衣内裤视频久久网站| 欧美日韩免费在线| 日韩视频不卡| 美女视频一区免费观看| 欧美在线电影| 国产精品二区在线观看| 亚洲高清三级视频| 亚洲国产精品视频一区| 久久成人人人人精品欧| 欧美亚洲视频在线观看| 国产精品九九久久久久久久| 亚洲欧洲日本mm| 亚洲黄页一区| 麻豆精品91| 亚洲成人在线视频播放 | 亚洲狼人综合| 蜜臀久久99精品久久久久久9| 久久精品麻豆| 欧美一进一出视频| 久久大逼视频| 韩国成人福利片在线播放| 久久精品国产一区二区电影| 久久久久久久久久久久久9999| 国产精品午夜视频| 亚洲素人在线| 久久大综合网| 一区在线免费| 久久久久久久91| 欧美高清在线精品一区| 亚洲美女电影在线| 欧美日韩一区二区三区在线| 亚洲视频欧美在线| 久久久欧美精品| 在线成人小视频| 女仆av观看一区| 亚洲美洲欧洲综合国产一区| 中文在线资源观看网站视频免费不卡 | 亚洲第一二三四五区| 亚洲精品一区二区网址| 欧美精品乱码久久久久久按摩| 亚洲精品午夜| 亚洲欧美另类在线| 一区二区在线不卡| 欧美黄色网络| 午夜精品久久久久| 欧美成人精品三级在线观看| 亚洲精品中文字幕有码专区| 欧美日韩午夜视频在线观看| 午夜精品国产更新| 欧美激情四色 | 免费视频一区二区三区在线观看| 亚洲激情在线观看视频免费| 欧美日韩dvd在线观看| 亚洲欧美成人| 亚洲国产精品www| 亚洲欧美怡红院| 伊人久久大香线蕉综合热线| 欧美激情中文字幕在线| 亚洲一卡二卡三卡四卡五卡| 免费看黄裸体一级大秀欧美| 亚洲一区图片| 亚洲精品视频在线看| 国产一区二区三区高清在线观看 | 午夜精品视频在线观看| 亚洲国产日韩精品| 国产精品一区二区欧美| 欧美华人在线视频| 久久婷婷综合激情| 在线视频欧美一区| 亚洲高清三级视频| 看片网站欧美日韩| 欧美在线高清视频| 宅男精品视频| 亚洲三级影院| 国色天香一区二区| 国产精品揄拍500视频| 欧美日韩视频一区二区| 狂野欧美性猛交xxxx巴西| 午夜精品久久久久久久99黑人| 亚洲性视频h| 亚洲电影免费在线观看|