• <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>

            Why so serious? --[NKU]schindlerlee

            2010年1月12日星期二.sgu223 狀態壓縮動態規劃

            2010年1月12日星期二.sgu223
             狀態壓縮動態規劃

            sgu223:n*n的棋盤上放置k個王的放置方法。
            基本方法和pku1185中的遞推方法是一樣的。
            都是先求出一行中的所有合法狀態,然后進行按行遞推,
            在遞推的過程中判斷兩行之間是否有沖突。

            #define L(n) (n << 1)
            #define R(n) (n >> 1)
            #define bin(n) (1 << n)
            #define low(n) (n & (-n))
            //http://m.shnenglu.com/schindlerlee/
            const int N = 10;
            int n,sum,full;
            int s[bin(N)],c[bin(N)],top;

            LL f[N
            +3][bin(N)][N*N];
            //行 最后一行狀態 已用的王的個數

            bool judgeRow(int t)
            {
              
            int stat = t,cnt = 0;
              
            int tp = 0,b = 0;
              
            while(t > 0) {
                  
            if(b & t) {
                      
            return false;
                  }
                  b 
            = t & 1,t >>= 1;
                  
            if(b == 1) cnt ++;
              }
              
            if(sum < cnt)
                
            return false;

              s[top] 
            = stat,c[top] = cnt,top++;
              
            return true;
            }

            bool contradict(int up,int down)
            return ((up & down) || (L(up) & down) || (R(up) & down)); }

            int main()
            {
              
            int i,j,k;
              scanf(
            "%d%d",&n,&sum);
              full 
            = bin(n) - 1;
              memset(f,
            0,sizeof(f));
              
            for(i = 0;i <= full;i++) {
                  judgeRow(i);
              }

              f[
            0][0][0= 1;
              
            for(i = 1;i <= n;i++) {
                  
            for(j = 0;j < top;j++) {
                      
            int s1 = s[j],c1 = c[j]; //current

                      
            for(k = 0;k < top;k++) {
                          
            for(int c2 = 0;c2 <= sum;c2++) {
                              
            int s2 = s[k];
                              
            if(!f[i-1][s2][c2] ||c1 + c2 > sum) continue;
                              
            //狀態不可達或者使用王的數量超過k
                
                              
            if(!contradict(s1,s2)) { //狀態不沖突
                                  f[i][s1][c1+c2] += f[i-1][s2][c2];
                              }
                          }
                      }
                  }
              }
              LL res 
            = 0;
              
            for(i = 0;i <= full;i++) {
                  res 
            += f[n][i][sum];
              }
              cout 
            << res << endl;

              
            return 0;
            }


             

            posted on 2010-01-13 22:39 schindlerlee 閱讀(1144) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

            久久精品www人人爽人人| 青青青青久久精品国产h久久精品五福影院1421 | 人妻少妇久久中文字幕一区二区| 久久久噜噜噜久久中文福利| 9191精品国产免费久久| 久久国产色av免费看| 国产福利电影一区二区三区久久久久成人精品综合 | 久久久黄色大片| 久久99精品国产一区二区三区| 伊人久久无码精品中文字幕| 国产精品美女久久久久网| 亚洲国产高清精品线久久| 精品国产福利久久久| 99久久国产精品免费一区二区| 很黄很污的网站久久mimi色| 国产一区二区精品久久| 亚洲第一极品精品无码久久| 青青草原综合久久大伊人导航| 精品国产福利久久久| 欧美一区二区三区久久综合| 一级a性色生活片久久无少妇一级婬片免费放 | 99久久99久久精品免费看蜜桃| 久久久久久久免费视频| 久久人人爽人人精品视频| 93精91精品国产综合久久香蕉| 久久99精品国产自在现线小黄鸭| 久久精品国产亚洲av麻豆蜜芽 | 久久99热只有频精品8| 亚洲欧美成人综合久久久| 久久久久亚洲av成人网人人软件 | 狠狠色婷婷久久一区二区| 中文成人无码精品久久久不卡| 人妻中文久久久久| 亚洲国产日韩综合久久精品| 亚洲一区精品伊人久久伊人| 99蜜桃臀久久久欧美精品网站 | 久久国产热精品波多野结衣AV| 久久婷婷激情综合色综合俺也去| 国产三级久久久精品麻豆三级| 久久香蕉国产线看观看99| 久久香蕉综合色一综合色88|