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

經典的狀態壓縮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>
            在线观看精品一区| 欧美专区亚洲专区| 香蕉久久一区二区不卡无毒影院| 国产精品久久久久一区二区三区| 久久精品系列| 欧美在线视频一区二区三区| 一本到高清视频免费精品| 久久综合99re88久久爱| 伊人久久久大香线蕉综合直播| 久久精品国产一区二区三区| 亚洲欧美日韩在线观看a三区 | 国产精品国产三级国产普通话三级 | 欧美精品在欧美一区二区少妇| 午夜日韩视频| 久久久国际精品| 欧美国产日韩精品| 国产精品一区在线播放| 影音先锋亚洲视频| 这里只有精品电影| 久久精品国语| 一区二区久久| 欧美国产精品v| 国产情侣久久| 午夜日韩激情| 国产日产亚洲精品| 91久久综合亚洲鲁鲁五月天| 亚洲你懂的在线视频| 六月丁香综合| 久久久久久夜| 在线观看日韩av先锋影音电影院 | 久久综合伊人77777尤物| 国产精品三级久久久久久电影| 亚洲一区二区三区四区五区午夜| 午夜精品亚洲| 国产偷自视频区视频一区二区| 在线视频中文亚洲| 9久草视频在线视频精品| 欧美精品国产精品| 在线性视频日韩欧美| 亚洲欧洲一区二区天堂久久| 亚洲一区二区在线观看视频| 国产伦精品一区二区三区| 欧美国产一区视频在线观看| 午夜在线不卡| 欧美福利专区| 国产亚洲精品久| 久久国产主播精品| 在线播放一区| 老鸭窝毛片一区二区三区| 伊人天天综合| 亚洲高清一区二区三区| 国产精品草莓在线免费观看| 日韩一级在线观看| 亚洲欧美日本国产专区一区| 国产精品激情电影| 久久琪琪电影院| 欧美三级韩国三级日本三斤| 欧美一区二区三区在线免费观看| 欧美中文字幕在线播放| 一区二区三区www| 欧美顶级少妇做爰| 羞羞答答国产精品www一本| 久久国产精品久久久久久电车 | 99re6这里只有精品| 亚洲欧美文学| 翔田千里一区二区| 亚洲精品欧美精品| 国产精品久久久爽爽爽麻豆色哟哟| 狠狠色狠狠色综合日日91app| 亚洲欧美综合精品久久成人| 久久电影一区| 日韩午夜中文字幕| 欧美高清视频在线| 亚洲精品一区二区三区樱花| 亚洲国产欧美一区二区三区久久 | 影音先锋一区| 久久乐国产精品| 欧美国产日韩精品免费观看| 精品成人久久| 欧美gay视频激情| 一区二区三区日韩| 日韩午夜精品视频| 国产精品国产三级国产专播精品人 | 91久久中文字幕| 中文亚洲免费| 国产欧美日韩一区二区三区在线观看 | 亚洲一区精品在线| 久久久久久高潮国产精品视| 影音先锋久久精品| 国产精品久久久久久久久久久久 | 亚洲高清在线精品| 久久国产视频网| 欧美伊人久久| 国产精品theporn| 欧美 日韩 国产在线| 欧美成人一区二区在线| 亚洲欧美日韩精品久久久| 欧美激情片在线观看| 久久精品国产一区二区三区| 国产精品一区二区三区久久| 91久久久国产精品| 亚洲乱码精品一二三四区日韩在线 | 在线播放豆国产99亚洲| 欧美激情四色| 亚洲欧洲精品一区二区三区波多野1战4 | 激情自拍一区| 免费成人高清视频| 亚洲福利视频一区二区| 99精品视频免费在线观看| 国产精品激情电影| 亚洲欧美在线播放| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产视频不卡| 欧美国产日韩一区二区| 一区二区高清视频| 亚洲国内精品在线| 久久亚洲私人国产精品va| 亚洲精品一区二区三区樱花| 国产美女精品在线| 欧美日韩另类丝袜其他| 久久se精品一区精品二区| 一区二区三区四区五区视频| 美日韩丰满少妇在线观看| 亚洲精品精选| 久久中文精品| 亚洲日本电影| 亚洲永久在线| 久久裸体视频| 欧美精品偷拍| 在线高清一区| 亚洲性图久久| 性色一区二区三区| 免费日韩av电影| 亚洲精品综合| 午夜精品久久久久久久久久久久久| 一区二区欧美激情| 欧美在线视频一区| 欧美激情亚洲视频| 国产一级揄自揄精品视频| 亚洲第一网站| 久久精品国产2020观看福利| 欧美第十八页| 午夜精品久久久99热福利| 久久在线免费观看| 国产精品播放| 欧美一区视频| 亚洲图片欧美一区| 亚洲视频免费在线观看| 亚洲精品视频在线观看免费| 日韩视频在线观看免费| 欧美护士18xxxxhd| 9久草视频在线视频精品| 欧美在线关看| 99国产精品99久久久久久| 欧美日韩国产成人在线| 国产精品亚洲综合| 亚洲欧美精品伊人久久| 亚洲精选中文字幕| 欧美色欧美亚洲另类二区| 亚洲在线一区| 久久久精品欧美丰满| 欧美一区二区在线免费观看| 国产视频精品va久久久久久| 欧美伊人久久久久久午夜久久久久| 久久精品国产99| 午夜精品成人在线| 欧美一级黄色录像| 亚洲风情在线资源站| 亚洲黄页一区| 狠狠色丁香久久婷婷综合丁香| 国产精品免费福利| 欧美亚男人的天堂| 巨乳诱惑日韩免费av| 久久精品国产视频| 最新高清无码专区| 国产精品亚发布| 美国十次了思思久久精品导航| 久久久亚洲精品一区二区三区| 欧美午夜精品一区| 一区二区三区精品视频在线观看| 亚洲黄色天堂| 欧美日韩理论| 亚洲欧美日韩中文视频| 久久偷窥视频| 国产精品成人播放| 一区二区三区成人精品| 亚洲资源在线观看| 国产亚洲欧美激情| 欧美黄色日本| 亚洲精品国产精品乱码不99按摩 | 一本综合精品| 久久综合精品一区| 亚洲一区二区三区四区在线观看 | 欧美精品自拍偷拍动漫精品| 久久动漫亚洲| 精品96久久久久久中文字幕无| 久久成人亚洲| 免费亚洲视频| 亚洲一区二区欧美| 国产伦精品一区二区三区在线观看 |