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

Why so serious? --[NKU]schindlerlee

2010年1月11日星期一.sgu131 pku2411 狀態壓縮動態規劃

2010年1月11日星期一.sgu131 pku2411
狀態壓縮動態規劃。

pku2411:
給一個m*n(m,n<=11)的棋盤,用1*2和2*1的矩形覆蓋這個棋盤,問有多少中方法對這個棋盤進行
完全覆蓋。

這題有組合數學上的公式,但是只能對棋盤上沒有障礙的情況有用,如果遇到有障礙的情況,只能
利用容斥原理進行計算,但是進行容斥原理的會非常復雜。

其實一看到數據范圍就應該想到使用位運算的狀態壓縮動態規劃。

主要的程序是
a表示要鋪滿的這一行的狀態,b表示的是鋪滿上一行的狀態a產生的下一行狀態。
然后使用狀態b繼續遞推。
 1 
 2 #include<iostream>
 3 #include<cstdio>
 4 #include<cstdlib>
 5 #include<cstring>
 6 #include<algorithm>
 7 using namespace std;
 8 typedef long long LL;
 9 const int maxint = 0x7fffffff;
10 const long long max64 = 0x7fffffffffffffffll;
11 #define bin(i) (1 << i)  /*1左移i位*/
12 #define emp(a,i) (!(a & bin(i))) /*判斷a的i位是否位0*/
13 
14 const int N = 1 << 11;
15 LL f[N], g[N];
16 int m, n;
17 int full;
18 
19 void dfs(int a, int b, LL k)
20 {
21     if (a == full) {  //將a鋪滿之后形成的所有下一行狀態b的鋪法都有k種
22         g[b] += k; //產生b的所有狀態求和
23         return;
24     }
25     for (int i = 0; i < m; i++) {
26         if (emp(a, i)) {
27             if (i < m - 1 && emp(a, i + 1)) {
28                 dfs(a | bin(i) | bin(i + 1), b, k);  //橫鋪
29             }
30             if (emp(b, i)) {
31                 dfs(a | bin(i), b | bin(i), k);  //豎鋪
32             }
33             break;
34         }
35     }
36 }
37 
38 int main()
39 {
40   int i, j, k;
41   while(scanf("%d%d"&m, &n) == 2 && m && n) {
42       memset(f,0,sizeof(f));
43       memset(g,0,sizeof(g));
44       full = (1 << m) - 1;
45       f[full] = 1;
46       for (k = 0; k <= n; k++) {
47           for (i = 0; i <= full; i++) {
48               if (f[i]) { //如果此行的狀態i可達
49                   dfs(i, 0, f[i]);
50               }
51           }
52           for (i = 0; i <= full; i++) {
53               f[i] = g[i];
54               g[i] = 0;
55           }
56       }
57       cout << f[0<< endl;
58   }
59   return 0;
60 }
61 

sgu131:pku2411的加強版
多了L型的瓷磚。這個最好是自己考慮一下,其實就是比上邊的代碼多了幾行

const int N = 512;
LL f[N], g[N];
int m, n;
int full;

void dfs(int a, int b, LL k)
{
    
if (a == full) {  //將a鋪滿之后形成的所有下一行狀態b的鋪法都有k種
        g[b] += k;
        
return;
    }
    
for (int i = 0; i < m; i++) {
        
/* 六種鋪法,按以下順序分別是
a:##  ##  ##  #  #    #
b:    #    #  #  ##  ##
         * 
*/
        
if (emp(a, i)) {
            
if (i < m - 1 && emp(a, i + 1)) {
                dfs(a 
| bin(i) | bin(i + 1), b, k);
                
if (emp(b, i))
                  dfs(a 
| bin(i) | bin(i + 1), b | bin(i), k);
                
if (emp(b, i + 1))
                  dfs(a 
| bin(i) | bin(i + 1), b | bin(i + 1), k);
            }
            
if (emp(b, i)) {
                dfs(a 
| bin(i), b | bin(i), k);
                
if (i > 0 && emp(b, i - 1))
                  dfs(a 
| bin(i), b | bin(i) | bin(i - 1), k);
                
if (i < m - 1 && emp(b, i + 1))
                  dfs(a 
| bin(i), b | bin(i) | bin(i + 1), k);
            }
            
break;
        }
    }
}



posted on 2010-01-13 22:11 schindlerlee 閱讀(1190) 評論(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>
            国产精品亚洲产品| 亚洲一区二区三区国产| 一区二区三区蜜桃网| 亚洲国产欧美一区| 日韩视频一区二区在线观看 | 久久久久国产精品午夜一区| 亚洲影视在线| 校园春色国产精品| 久久青草福利网站| 欧美国产免费| 99re66热这里只有精品4| 亚洲视频1区2区| 久久久久久久久蜜桃| 欧美激情综合网| 国产精品免费网站在线观看| 国外成人性视频| a91a精品视频在线观看| 亚洲欧美日韩在线| 欧美大片免费久久精品三p| 99热精品在线| 快播亚洲色图| 国产欧美va欧美va香蕉在| 亚洲精品免费一区二区三区| 午夜国产一区| 亚洲激情电影中文字幕| 亚洲无线视频| 欧美成人69av| 精品不卡在线| 欧美伊人久久久久久午夜久久久久| 欧美插天视频在线播放| 亚洲午夜精品久久久久久app| 久久午夜av| 欧美激情视频免费观看| 一区二区三区欧美视频| 久久中文字幕一区| 在线视频日韩精品| 六月婷婷久久| 韩国三级电影一区二区| 午夜精品免费视频| 亚洲精选国产| 麻豆久久久9性大片| 国产欧美91| 午夜精品一区二区三区在线播放| 亚洲黄色一区| 免费观看欧美在线视频的网站| 国产日韩欧美视频| 亚洲欧美成人一区二区在线电影| 亚洲国产一区二区精品专区| 久久人人爽人人| 韩国av一区二区三区在线观看| 亚洲欧美日韩精品久久亚洲区| 亚洲国产精品成人综合色在线婷婷| 性高湖久久久久久久久| 欧美日韩直播| 亚洲在线日韩| 亚洲一区网站| 国产伦精品一区二区| 亚洲女同在线| 亚洲欧美电影院| 国产日韩欧美综合| 欧美影院一区| 欧美永久精品| 永久久久久久| 亚洲国产第一| 欧美日韩不卡一区| 亚洲一区二区三区精品视频| 一本色道久久综合狠狠躁篇的优点| 欧美日韩国产精品一卡| 亚洲一二区在线| 亚洲男人的天堂在线| 国产一区二区三区在线观看免费| 久久精品国产精品亚洲综合| 久久精品五月婷婷| 亚洲第一区在线| 亚洲精品五月天| 国产精品爽爽爽| 老司机午夜精品视频在线观看| 麻豆精品传媒视频| 一区二区高清视频| 亚洲欧美国产高清| 亚洲成色最大综合在线| 亚洲人成在线免费观看| 国产精品裸体一区二区三区| 久久久噜噜噜久久狠狠50岁| 欧美xart系列在线观看| 亚洲一区二区在线看| 性色一区二区| 亚洲美女精品久久| 亚洲欧美不卡| 亚洲人成艺术| 亚洲欧美成aⅴ人在线观看| 1024成人| 亚洲欧美日韩精品久久久久| 一区二区三区久久| 亚洲大胆人体在线| 欧美高清在线视频观看不卡| 欧美日韩精品久久久| 久久精品毛片| 欧美美女日韩| 免费一级欧美在线大片| 欧美性大战久久久久| 老司机一区二区三区| 国产精品ⅴa在线观看h| 欧美高清一区| 国产一区二区在线观看免费| 日韩午夜在线电影| 在线日韩电影| 欧美影院午夜播放| 亚洲欧美视频| 欧美日韩在线播放三区四区| 久久久视频精品| 国产精品v日韩精品| 欧美国产三区| 国产一区二区三区最好精华液| 一区二区三区鲁丝不卡| 亚洲美女精品一区| 久久天天综合| 久久久久国产一区二区三区四区| 欧美日韩免费观看中文| 欧美激情精品久久久| 国产在线国偷精品产拍免费yy| 在线一区视频| 亚洲网站在线| 欧美日韩一视频区二区| 亚洲第一级黄色片| 亚洲电影欧美电影有声小说| 欧美在线一二三区| 久久精品国产99国产精品澳门| 国产精品卡一卡二| 中文网丁香综合网| 亚洲欧美国产另类| 国产精品成人一区二区三区吃奶| 亚洲欧洲精品一区二区三区不卡 | 欧美一区二区三区啪啪| 欧美午夜电影在线| 亚洲精品婷婷| 亚洲一区欧美一区| 欧美日本亚洲韩国国产| 亚洲日本中文字幕区| a91a精品视频在线观看| 欧美日韩国产限制| 一本色道久久88综合亚洲精品ⅰ| 亚洲图片欧美午夜| 国产精品捆绑调教| 新狼窝色av性久久久久久| 久久精品观看| 在线日韩av永久免费观看| 久久久在线视频| 欧美激情性爽国产精品17p| 亚洲国产精品久久久久秋霞蜜臀 | 久久精品国产久精国产思思| 国产午夜精品久久| 久久成人免费网| 欧美福利视频| 亚洲一区二区三区精品在线| 欧美精品乱码久久久久久按摩 | 亚洲美女尤物影院| 欧美母乳在线| 亚洲免费在线观看| 欧美99在线视频观看| 日韩视频一区二区三区| 国产精品porn| 久久免费精品视频| 91久久综合| 欧美一级片久久久久久久| 伊人蜜桃色噜噜激情综合| 欧美国产日韩a欧美在线观看| 一本色道88久久加勒比精品 | 美女成人午夜| 在线亚洲免费| 韩国三级在线一区| 欧美日韩国产高清| 久久精品成人欧美大片古装| 亚洲激情在线观看视频免费| 欧美亚洲一区| 日韩一级大片| 国内自拍一区| 国产精品国产三级国产专区53 | 亚洲欧洲日韩综合二区| 欧美性jizz18性欧美| 久久亚洲免费| 亚洲一区二区在线看| 欧美激情国产日韩| 久久精品国产综合精品| 一区二区三区免费网站| 韩国v欧美v日本v亚洲v| 国产精品久久久久久久久久三级| 久久婷婷蜜乳一本欲蜜臀| 亚洲午夜一区二区三区| 最近中文字幕mv在线一区二区三区四区| 香蕉久久夜色| 一本色道久久综合狠狠躁的推荐| 国产主播一区二区三区四区| 欧美日精品一区视频| 看欧美日韩国产| 久久国产88| 性8sex亚洲区入口| 亚洲自拍啪啪| 亚洲一区尤物| 99亚洲一区二区|