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

經(jīng)典的狀態(tài)壓縮DP,《算法藝術(shù)與信息學(xué)競(jìng)賽》的例題。f[i][j]表示前i行,最后兩行狀態(tài)為二進(jìn)制數(shù)j,嵌入的最多芯片數(shù)。第i行到第i+1行用DFS進(jìn)行狀態(tài)轉(zhuǎn)移。
由于第i+1行只和第i行有關(guān),故可以用滾動(dòng)數(shù)組優(yōu)化。

/*************************************************************************
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) 評(píng)論(3)  編輯 收藏 引用 所屬分類: 動(dòng)態(tài)規(guī)劃
Comments
  • # re: [動(dòng)態(tài)規(guī)劃]pku1038
    Run&Run
    Posted @ 2007-11-21 15:41
    大牛同志,你的方法和<<算法藝術(shù)與信息學(xué)競(jìng)賽上>>寫的不太一樣....
    狀態(tài)壓縮的DP......研究了我足足5個(gè)小時(shí)才看明白.....
    你開(kāi)頭的解釋也太少了吧,光那個(gè)mask[]就想了我快兩個(gè)小時(shí).
    你要照顧新人撒,多寫點(diǎn)解釋撒.
    話說(shuō)回來(lái),你位運(yùn)算確實(shí)用得出神入化,佩服!  回復(fù)  更多評(píng)論   
  • # re: [動(dòng)態(tài)規(guī)劃]pku1038
    Felicia
    Posted @ 2007-11-21 15:44
    mask表示所有可能的放置情況  回復(fù)  更多評(píng)論   
  • # re: [動(dòng)態(tài)規(guī)劃]pku1038
    prister
    Posted @ 2016-05-18 01:05
    @Run&amp;Run
    里面的兩處>?=是什么意思  回復(fù)  更多評(píng)論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美jizzhd精品欧美巨大免费| 欧美一二三区精品| 欧美日韩精品欧美日韩精品 | 亚洲国产清纯| 欧美韩国日本综合| 亚洲韩国日本中文字幕| 99精品热视频只有精品10| 亚洲无玛一区| 久久久噜噜噜| 欧美日韩不卡一区| 国产欧美日韩免费| 亚洲国产精品精华液网站| 夜夜嗨av一区二区三区四区| 欧美激情综合| 亚洲国产精品一区二区三区| 亚洲高清在线观看| 中日韩高清电影网| 久久免费的精品国产v∧| 欧美激情一区二区三区在线视频| 亚洲卡通欧美制服中文| 欧美一区二区成人| 欧美激情亚洲激情| 国产精品夜夜夜一区二区三区尤| 永久免费毛片在线播放不卡| 99在线视频精品| 久久尤物视频| 中日韩男男gay无套| 久久综合久久综合九色| 国产精品免费在线| 日韩午夜在线电影| 蜜桃av一区二区三区| 国产精品99久久不卡二区| 久久婷婷av| 国产麻豆视频精品| 亚洲少妇诱惑| 亚洲国产精品免费| 久久久噜噜噜久久中文字免| 国产精品久久久久久久久久免费看| 国内精品美女在线观看| 亚洲欧美日韩第一区| 亚洲黄色一区| 久久亚洲精品网站| 国产自产在线视频一区 | 欧美一区二区三区日韩视频| 欧美激情在线观看| 久久久美女艺术照精彩视频福利播放| 欧美小视频在线| 亚洲精品一区二区在线观看| 久久久91精品国产| 欧美一级网站| 国产欧美综合在线| 亚洲欧美日韩精品久久| 日韩视频久久| 欧美日韩精品二区| 一区二区三区国产| 日韩视频在线观看| 欧美精品手机在线| 在线亚洲成人| 亚洲视频二区| 国产精品日韩欧美大师| 午夜久久久久| 欧美亚洲系列| 激情综合五月天| 美腿丝袜亚洲色图| 欧美暴力喷水在线| 一本一道久久综合狠狠老精东影业 | 亚洲大片一区二区三区| 久久久精彩视频| 欧美一区二区精品久久911| 国产美女精品| 久久噜噜噜精品国产亚洲综合| 性欧美办公室18xxxxhd| 国语自产在线不卡| 老司机免费视频久久| 久久久久国产一区二区| 最近中文字幕日韩精品 | 久久久久久一区二区| 久久男女视频| 夜夜爽www精品| 亚洲一级一区| 伊人成人网在线看| 亚洲精品1区2区| 国产精品白丝av嫩草影院| 欧美一区免费视频| 久色成人在线| 亚洲女人天堂av| 久久久xxx| 亚洲一区二区三区高清| 欧美一区二区视频在线观看| 亚洲国产清纯| 亚洲一区二区在线免费观看视频| 国语自产精品视频在线看8查询8| 亚洲第一区在线| 国产精品乱码久久久久久| 免费不卡亚洲欧美| 欧美视频一区二区三区…| 久久亚洲综合网| 欧美午夜视频一区二区| 麻豆成人在线播放| 国产精品s色| 欧美激情1区2区| 国产一区二区高清视频| 亚洲国产精品一区二区第一页| 国产精品美女久久久浪潮软件| 久久在线免费视频| 国产精品国产三级国产aⅴ入口| 久久综合网络一区二区| 欧美日韩综合一区| 欧美成人国产| 国产自产v一区二区三区c| 99综合视频| 亚洲激情网站免费观看| 西瓜成人精品人成网站| 亚洲图片欧美日产| 欧美成人激情在线| 久久野战av| 国产情侣久久| 亚洲一区免费| 亚洲一区二区三区在线播放| 欧美不卡激情三级在线观看| 久久久一二三| 国产亚洲午夜| 亚洲欧美另类在线观看| 亚洲视频中文| 欧美三级网址| 99国产精品久久久久久久久久 | 欧美激情视频在线播放| 久久久蜜桃一区二区人| 国产精品羞羞答答xxdd| 亚洲免费电影在线观看| 亚洲三级电影在线观看| 久久一区二区三区av| 久久伊人精品天天| 国产亚洲亚洲| 欧美在线观看网址综合| 久久成人免费日本黄色| 国产女优一区| 香港久久久电影| 久久久国产精彩视频美女艺术照福利| 欧美午夜精品久久久久久人妖| 亚洲欧洲另类| 在线一区免费观看| 欧美性大战xxxxx久久久| 日韩一二在线观看| 亚洲欧美成人综合| 国产乱人伦精品一区二区 | 亚洲黄色视屏| 欧美大尺度在线观看| 91久久国产自产拍夜夜嗨| 亚洲裸体在线观看| 欧美日本韩国| 亚洲婷婷国产精品电影人久久| 香蕉免费一区二区三区在线观看 | 一本色道久久综合亚洲精品不卡 | 欧美性大战久久久久| 亚洲一区制服诱惑| 久久美女性网| 亚洲免费观看| 国产精品久久久久一区| 欧美亚洲视频在线观看| 欧美a级大片| 亚洲午夜精品网| 国内精品久久久久久 | 国产啪精品视频| 久久er精品视频| 亚洲全部视频| 性做久久久久久免费观看欧美| 国产一区二区三区在线观看免费 | 亚洲欧美日本日韩| 欧美a级片网| 亚洲欧美日韩一区| 在线日韩视频| 国产精品久久久久久妇女6080| 久久国产精品久久久久久久久久 | 日韩视频一区二区在线观看 | 亚洲精品在线看| 国产精品国产三级国产普通话三级 | 久久成人免费| 亚洲九九精品| 国产日韩欧美一区在线 | 亚洲第一综合天堂另类专| 欧美国产精品劲爆| 欧美在线观看视频在线| 亚洲欧洲精品一区二区精品久久久| 亚洲欧美欧美一区二区三区| 亚洲成色777777在线观看影院| 欧美性色视频在线| 欧美xart系列在线观看| 欧美亚洲尤物久久| 一区二区三区国产在线| 亚洲第一福利视频| 久久精品中文| 午夜久久电影网| 亚洲一区二区毛片| 亚洲国语精品自产拍在线观看| 国产精品一区二区三区四区五区 | 在线观看国产精品网站| 国产欧美高清| 国产精品私房写真福利视频| 欧美日本韩国一区二区三区|