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

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
            數據加載中……

            POJ 1143 Number Game 動態規劃+位操作

            題目大意:
            兩個人玩游戲。輪流取數字,范圍在1~20之間。
            規定:
            1. 取過的數字不能再取。
            2. 取過的數字的倍數不能再取。
            3. 任意個(2)的和不能再取。

            當某個人發現沒有數字可取時,他就輸了。
            給出一個“殘局”。問,我現在應該怎么取,才能保證勝利。

            思路:
            其實這個也不是很難的博弈問題。只是搜索就可以解決了。要用位來表示當前剩余數字的狀態,
            方便保存動態規劃的結果。


            #include <stdio.h>

            #define N 20

            char dp[2][1 << (N + 1)];

            __inline 
            int use(int visited, int idx)
            {
                
            int i;

                
            for (i = 0; i + idx <= N; i++{
                    
            if (visited & (1 << i))
                        visited 
            |= 1 << (i + idx);
                }

                
            return visited;
            }


            int dfs(int my_step, int visited)
            {
                
            int i, r;

                
            if (visited == (1 << (N + 1)) - 1
                    
            return !my_step;
                
                r 
            = dp[my_step][visited];
                
            if (r)
                    
            return r - 1;

                
            for (i = 2; i <= N; i++{
                    
            if (visited & (1 << i))
                        
            continue;
                    r 
            = dfs(!my_step, use(visited, i));
                    
            if (my_step && r)
                        
            return 1;
                    
            if (!my_step && !r)
                        
            return 0;
                }


                dp[my_step][visited] 
            = !my_step + 1;
                
            return !my_step;
            }


            int main()
            {
                
            int n, v, i, arr[24], cnt, t;

                freopen(
            "e:\\test\\in.txt""r", stdin);

                
            for (t = 1; scanf("%d"&n), n; t++{
                    v 
            = ((1 << (N + 1)) - 1& ~2;
                    
            while (n--{
                        scanf(
            "%d"&i);
                        v 
            &= ~(1 << i);
                    }

                    cnt 
            = 0;
                    
            for (i = 2; i <= N; i++{
                        
            if (v & (1 << i))
                            
            continue;
                        
            if (dfs(0, use(v, i)))
                            arr[cnt
            ++= i;
                    }

                    printf(
            "Test Case #%d\n", t);
                    
            if (cnt) {
                        printf(
            "The winning moves are:");
                        
            for (i = 0; i < cnt; i++
                            printf(
            " %d", arr[i]);
                        printf(
            "\n");
                    }
             else 
                        printf(
            "There's no winning move.\n");
                    printf(
            "\n");
                }


                
            return 0;
            }


            posted on 2010-02-27 16:55 糯米 閱讀(1129) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            中文字幕久久久久人妻| 久久午夜无码鲁丝片秋霞| 精品国产乱码久久久久久人妻 | 国产91色综合久久免费| av午夜福利一片免费看久久| 久久婷婷久久一区二区三区| 久久亚洲中文字幕精品一区四| 久久综合久久综合亚洲| 久久99精品久久只有精品| 91久久精品无码一区二区毛片| 欧美成人免费观看久久| 韩国无遮挡三级久久| 亚洲精品第一综合99久久| 97久久国产亚洲精品超碰热| 久久国产精品偷99| 精品久久人妻av中文字幕| 久久国产成人午夜aⅴ影院| 久久久无码精品亚洲日韩按摩 | 久久无码高潮喷水| 亚洲一区二区三区日本久久九| 精品伊人久久大线蕉色首页| 精品国产婷婷久久久| 97热久久免费频精品99| 亚洲综合精品香蕉久久网| 婷婷久久综合九色综合绿巨人| 色成年激情久久综合| 成人久久久观看免费毛片| 亚洲伊人久久精品影院| 国产精品99久久久精品无码| 久久久国产精华液| 伊人久久精品线影院| 九九99精品久久久久久| 久久精品中文字幕无码绿巨人| 狠狠色丁香久久婷婷综合_中 | 狠狠色丁香婷婷综合久久来来去| 精品国际久久久久999波多野| 久久久久国产精品嫩草影院| 久久中文字幕人妻熟av女| 亚洲伊人久久综合影院| 亚洲国产成人久久精品99 | 国内精品欧美久久精品|