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

posts - 6,comments - 4,trackbacks - 0


   這道題目是我的摯友興哥給的,程序的流程非常清晰,可謂所見及所編了.

   不過這道題目有個難點,就是“游戲者通過鍵盤輸入自己報的數……”,題目中沒有要求每輪報數時玩家輸入要輸入的個數,我們怎么知道用戶輸入了多少個數字呢?
   這里給出一個“有Bug的”解決方案:(強制地)要求玩家在同一行內輸入兩個數字,然后定義一個字符串*buf,用gets(buf)讀入,然后判斷兩個數字之間的space_index是否滿足space_index∈(0, strlen(buf) - 1),滿足則輸入了兩個數字,若不滿足或沒有space,那么input_n就等于1.
   后來興哥降低了難度,直接給input_n的值就好了,所以一切都是行云流水.

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <time.h>
 4 
 5 #define PLAYER 1
 6 #define COMPUTER -1
 7 
 8 int main()
 9 {
10     srand((unsigned)time(NULL));
11     int turn = rand() % 2 ? PLAYER : COMPUTER, rest = 30, input_n = 0, i;
12     
13     while (rest >= 0)
14     {
15         if (rest == 0)
16         {
17             if (turn == PLAYER)
18                 printf("Computer won! You lost!\n");
19             else
20                 printf("You won! Computer lost!\n");
21             break;
22         }
23         if (turn == PLAYER)
24         {
25             printf("Now it's your turn!\n");
26             printf("You report: ");
27             scanf("%d"&input_n);
28             turn = COMPUTER;
29         }
30         else if (turn == COMPUTER)
31         {
32             printf("Now it's computer's turn!\n");
33             if (rest % 3 == 1)
34                 input_n = 1;
35             else if (rest % 3 == 2)
36                 input_n = 2;
37             else
38             {
39                 input_n = rand() % 3;
40                 while (input_n == 0)
41                     input_n = rand() % 3;
42             }
43             printf("Computer reports: %d\n", input_n);
44             turn = PLAYER;
45         }
46 
47         rest -= input_n;
48         printf("Now, the max number is %d.\n"30 - rest);
49         putchar('\n');
50     }
51     //system("pause");
52     return 0;
53 }
54 
   
   為了增強代碼的可讀性,定義常量PLAYER和COMPUTER;為了避免GCC在Windows下隨機數的重復性,line 10用srand()“隨機化”一下.
   編寫過程中一個Bug的出現引發了我的思考,就是當還剩下1個數的時候,輪到Computer報數,這個時候,計算機若開始隨機報數個數,且得到2,那么游戲的贏家必為Computer,這完全沒有問題.問題引申一下,如果當還剩下2個數的時候,輪到Computer報數,若隨機到了1,那么Computer等于直接把勝利拱手讓出,這里我們作為Computer的支持者,為了必勝,可以在還有一步之遙的時候進行AI機動,于是將line 30 ~ line 45改進如下:

1      if (turn == COMPUTER) if (rest > 2)
2         {
3             ////
4             // Normal solution block
5             ////
6         }
7         else input_n = rest;

   這樣只要一有必殺的機會就迅速拿下玩家,這里程序不是根據Normal solution的運行方式,而是隨機應變,只改變了小小兩行就實現了我的第一個AI初步.
   但是自己和ThinkPad打了好幾盤,始終沒有戰勝自己具有CORE i5大腦的Computer,懷疑邏輯錯誤的時候我還是想到了Computer的選數方法有可能就是本題目的博弈必勝解,不過這只是懷疑,有待驗證.
   至于如何擊敗Computer,這里給出兩個比較好的研究思路:1.搶三十的數據規模也許太小了,所以可以找找更大數字,比如五十甚至更大,正如國際上為了限制中國的乒乓球的勝率把積分制從7分制改到11分制,理論上降低了勝率.但如果理論勝率降低之后,程序依然有必勝解,也許就… 2.問題還是一樣,可以理想地假設Absolute solution不存在,可以用回溯法去遍歷解答樹,來找到我們自己的必勝解,剪枝在這里顯得尤為重要,就留到以后再思考…

posted on 2013-12-21 16:10 molasses 閱讀(1370) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久九九电影| 久久国产精品久久久久久| 欧美成人午夜激情视频| 亚洲黄色小视频| 亚洲国产视频a| 欧美99在线视频观看| 91久久国产综合久久蜜月精品 | 亚洲日本欧美天堂| 欧美成人久久| 欧美女激情福利| 亚洲一品av免费观看| 亚洲一区亚洲| 国外视频精品毛片| 欧美国产日韩一二三区| 欧美激情五月| 午夜在线精品偷拍| 久久国产一二区| 99精品99| 欧美在线一二三区| 亚洲免费高清视频| 一区二区动漫| 尤物精品在线| 一本久道久久久| 狠狠色香婷婷久久亚洲精品| 亚洲国产专区校园欧美| 欧美中文字幕在线播放| 亚洲自拍高清| 91久久久久久久久| 亚洲无限乱码一二三四麻| 国产在线欧美日韩| 91久久精品美女高潮| 国产精品久久久久影院亚瑟| 卡通动漫国产精品| 欧美精品久久久久久久久久| 性欧美超级视频| 欧美α欧美αv大片| 亚洲女性喷水在线观看一区| 久久综合色婷婷| 亚洲女人天堂av| 欧美aⅴ一区二区三区视频| 西西人体一区二区| 欧美激情一二三区| 久久久欧美一区二区| 国产精品99一区二区| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品成人一区| 亚洲国产黄色片| 国产一区二区三区无遮挡| 亚洲黄页视频免费观看| 韩国精品在线观看| 亚洲一区二区毛片| 一本色道久久综合| 嫩草成人www欧美| 久久精品国产亚洲aⅴ| 国产精品播放| 日韩一二三区视频| 99re6热在线精品视频播放速度| 性18欧美另类| 午夜影视日本亚洲欧洲精品| 欧美日韩精品久久| 亚洲啪啪91| 亚洲国产精品欧美一二99| 久久久另类综合| 久久久久国产一区二区三区四区| 国产精品劲爆视频| 亚洲天堂av电影| 亚洲一区国产精品| 欧美久久久久久蜜桃| 亚洲人成啪啪网站| 亚洲精品一区二区三| 蜜臀av一级做a爰片久久| 欧美成年人在线观看| 亚洲第一福利视频| 免费在线看一区| 亚洲国产欧美一区二区三区丁香婷| 激情综合五月天| 久久一区二区三区国产精品| 久久中文字幕一区| 亚洲成色www久久网站| 巨胸喷奶水www久久久免费动漫| 乱码第一页成人| 亚洲国产一区二区视频 | 亚洲成色777777女色窝| 亚洲国产精品www| 卡一卡二国产精品| 亚洲欧洲综合另类| 在线视频亚洲欧美| 国产精品免费在线| 欧美一区二区三区四区在线| 久久久久久69| 亚洲国产精品va在线看黑人| 欧美日韩精品伦理作品在线免费观看| 日韩一二三在线视频播| 久久99伊人| 亚洲国产欧美一区| 欧美日一区二区三区在线观看国产免 | 亚洲三级毛片| 国产精品第2页| 久久国产精品99国产精| 欧美国产日本高清在线| 亚洲在线成人| 黄色资源网久久资源365| 欧美福利在线| 亚洲欧美一区二区三区在线| 美女脱光内衣内裤视频久久网站| 91久久国产综合久久91精品网站| 国产精品高潮呻吟久久| 欧美在线视频日韩| 亚洲精品少妇| 久久先锋影音| 亚洲午夜av在线| 韩国视频理论视频久久| 欧美乱大交xxxxx| 香蕉av777xxx色综合一区| 亚洲国产91色在线| 久久精品国产99国产精品澳门| 亚洲精品久久久久久久久久久久| 国产精品日韩在线观看| 欧美黄色免费| 久久高清国产| 亚洲天堂av高清| 亚洲国产欧美日韩| 久久久亚洲成人| 亚洲欧美日韩天堂一区二区| 亚洲欧洲一二三| 国内精品一区二区三区| 国产精品久久久久久久久免费樱桃 | 麻豆91精品91久久久的内涵| 亚洲在线中文字幕| 日韩午夜免费| 亚洲激情av| 欧美国产精品va在线观看| 香蕉视频成人在线观看| 亚洲一区二区三区涩| 99re6热在线精品视频播放速度 | 国产精品国产福利国产秒拍| 免费观看成人www动漫视频| 亚洲免费在线观看视频| 在线亚洲一区| 中文亚洲字幕| 亚洲一区二区三区精品视频| 99精品欧美一区| 99pao成人国产永久免费视频| 欧美大色视频| 欧美黄色免费网站| 免费成人小视频| 裸体一区二区三区| 裸体歌舞表演一区二区| 蜜月aⅴ免费一区二区三区| 久久久久在线| 欧美sm重口味系列视频在线观看| 麻豆成人小视频| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久视频一区二区| 免费在线视频一区| 暖暖成人免费视频| 亚洲第一页中文字幕| 亚洲大胆视频| 亚洲日韩中文字幕在线播放| 亚洲国产欧美在线人成| 亚洲精品系列| 制服丝袜激情欧洲亚洲| 亚洲在线视频网站| 亚洲欧美日韩精品久久奇米色影视 | 久久婷婷麻豆| 欧美激情亚洲国产| 国产精品电影网站| 狠狠色狠狠色综合日日五| 亚洲欧洲精品一区二区| 日韩视频免费| 欧美一级片在线播放| 麻豆视频一区二区| 亚洲日本在线观看| 亚洲欧美日韩在线不卡| 狂野欧美激情性xxxx| 欧美私人啪啪vps| 精品成人在线| 一本色道久久综合亚洲精品高清 | 亚洲国产欧美久久| 亚洲嫩草精品久久| 久久久久成人网| 亚洲国产欧美一区二区三区久久| 久久国产精品亚洲77777| 久久亚洲一区二区三区四区| 男人的天堂成人在线| 在线亚洲电影| 欧美一区二区三区免费看| 久久久国产成人精品| 欧美中文字幕在线播放| 久久精品盗摄| 欧美刺激午夜性久久久久久久| 亚洲美女黄网| 香蕉久久夜色精品国产使用方法| 久久av一区二区三区漫画| 久久精品一区四区| 欧美精品播放| 国产日韩欧美中文在线播放| 在线看日韩av| 亚洲资源在线观看| 蜜月aⅴ免费一区二区三区 |