版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、ACM程序設(shè)計杭州電子科技大學 劉春英 2022/7/192月賽,你 了嗎?報名2022/7/193每周一星(11):Dan2022/7/194第十二講組合博弈入門(Simple Game Theory)2022/7/195導(dǎo)引游戲(1) 玩家:2人;(2) 道具:23張撲克牌;(3) 規(guī)則:游戲雙方輪流取牌;每人每次僅限于取1張、2張或3張牌;撲克牌取光,則游戲結(jié)束;最后取牌的一方為勝者。2022/7/196基本思路?請陳述自己的觀點2022/7/197第一部分簡單取子游戲(組合游戲的一種)2022/7/198什么是組合游戲有兩個玩家;游戲的操作狀態(tài)是一個有限的集合(比如:限定大小的棋盤);
2、游戲雙方輪流操作;雙方的每次操作必須符合游戲規(guī)定;當一方不能將游戲繼續(xù)進行的時候,游戲結(jié)束,同時,對方為獲勝方;無論如何操作,游戲總能在有限次操作后結(jié)束;2022/7/199概念:必敗點和必勝點(P點 & N點)必敗點(P點) :前一個選手(Previous player)將取勝的位置稱為必敗點。 必勝點(N點) :下一個選手(Next player)將取勝的位置稱為必勝點。 2022/7/1910必敗(必勝)點屬性(1) 所有終結(jié)點是必敗點(P點);(2) 從任何必勝點(N點)操作,至少有一種方法可以進入必敗點(P點);(3)無論如何操作, 從必敗點(P點)都只能進入必勝點(N點).2022
3、/7/1911取子游戲算法實現(xiàn) 步驟1:將所有終結(jié)位置標記為必敗點(P點);步驟2: 將所有一步操作能進入必敗點(P點)的位置標記為必勝點(N點)步驟3:如果從某個點開始的所有一步操作都只能進入必勝點(N點) ,則將該點標記為必敗點(P點) ;步驟4: 如果在步驟3未能找到新的必?。≒點),則算法終止;否則,返回到步驟2。2022/7/1912課內(nèi)練習:Subtraction Games:subtraction set S = 1, 3, 4x : 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14Pos: P N P N N N N P N P N N N N P2022/
4、7/1913實戰(zhàn)練習kikis game 2022/7/1914第二部分Nim游戲2022/7/1915Nim游戲簡介有兩個玩家;有三堆撲克牌(比如:可以分別是 5,7,9張);游戲雙方輪流操作;玩家的每次操作是選擇其中某一堆牌,然后從中取走任意張;最后一次取牌的一方為獲勝方;2022/7/19162022/7/1917初步分析(0, 0, 0) (0, 0, x) (0, 1, 1) (0, k, k) P-position P-position P-position N-position (14, 35, 46) ? 2022/7/1918引入概念:Nim-Sum定義: 假設(shè) (xm x0
5、)2 和(ym y0)2 的nim-sum是(zm z0)2,則我們表示成 (xm x0)2 (ym y0)2 = (zm z0)2, 這里,zk = xk + yk (mod 2)(k=0m).2022/7/1919定理一: 對于nim游戲的某個位置(x1,x2,x3),當且僅當它各部分的nim-sum等于0時(即x1x2x3=0),則當前位于必敗點。定理一也適用于更多堆的情況2022/7/1920定理一的證明 2022/7/1921思考(1):有了定理一,如何判斷某個游戲的先手是輸還是贏?2022/7/1922思考(2):對于必勝點,如何判斷有幾種可行的操作方案?2022/7/1923實例
6、分析(HDOJ_1850)Being a Good Boy in Spring Festival 2022/7/1924第三部分Graph Games &Sprague-Grundy Function2022/7/1925What is the graph game ?(1) Player I moves first, starting at x0.(2) Players alternate moves.(3) At position x, the player whose turn it is to move chooses a position y F(x).(4) The player
7、who is confronted with a terminal position at his turn, and thus cannot move, loses.2022/7/1926Example about graph game:0,0,01,0,00,0,10,1,05,7,92,0,02022/7/1927The Sprague-Grundy Function.Definition: The Sprague-Grundy function of a graph, (X,F), is a function, g, defined on X and taking non-negati
8、ve integer values, such thatg(x) =minn 0 : ng(y) for y F(x). (1)In words, g(x) the smallest non-negative integer not found among the Sprague-Grundy values of the followers of x.g(x) =mexg(y) : y F(x). (2)2022/7/1928Use of the Sprague-Grundy Function:P-positions: Positions x for which g(x) = 0 N-posi
9、tions: Positions x for which g(x) 0 2022/7/1929Exercise:What is the SG-value of the subtraction game with subtraction set S = 1, 2, 3?x 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14. . .g(x) 0 1 2 3 0 1 2 3 0 1 2 3 0 1 2. . .2022/7/1930Question:What can the S-G value describe?2022/7/1931Part 4:Sums of Combinat
10、orial Games2022/7/1932What is so-called “Sums of Combinatorial Games”?2022/7/1933Theorem 2.If gi is the Sprague-Grundy function of Gi , i = 1, . . . , n, then G = G1 + + Gn has Sprague-Grundy function g(x1, . . . , xn) = g1(x1) gn(xn).2022/7/1934Applications:Sums of three Subtraction Games.In the fi
11、rst game: m = 3 and the pile has 9 chips. In the second: m = 5 and the pile has 10 chips. In the third:m = 7 and the pile has 14c hips.g(9, 10, 14) =?2022/7/1935附:參考源碼(HDOJ-1536)#include#include#includeusing namespace std;int k,a100,f10001;int mex(int p) int i,t; bool g101=0; for(i=0;ik;i+) t=p-ai; if(t0) break; if(ft=-1) ft=mex(t); gft=1; for(i=0;i+) if(!gi) return i; int main() int n,i,m,t,s; while(scanf(%d,&k),k) for(i=0;ik;i+) scanf(%d,&ai); sort(a,a+k); memset(f,-1,sizeof(f); f0=0; scanf(%d,&n); while(n-) scanf(%d,&m); s=0; whil
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度新型海洋運輸合同保險險別及理賠流程3篇
- 2025版離婚房產(chǎn)分割與購房款分期支付合同范本4篇
- 二零二五版家用節(jié)電器銷售代理合同規(guī)范3篇
- 蘭州外語職業(yè)學院《消防工程施工技術(shù)與組織》2023-2024學年第一學期期末試卷
- 二零二五年度離婚協(xié)議書模板定制與婚姻財產(chǎn)評估合同3篇
- 專業(yè)幕墻工程勞務(wù)承包合同(2024)版B版
- 二零二五白酒銷售顧問品牌宣傳與推廣協(xié)議2篇
- 2025年度光伏發(fā)電項目勞務(wù)分包與電站運營合同4篇
- 2025年私人房產(chǎn)轉(zhuǎn)讓協(xié)議書(含裝修標準細則)3篇
- 2025年度毛竹砍伐與鄉(xiāng)村振興戰(zhàn)略合作框架合同4篇
- 課題申報書:大中小學鑄牢中華民族共同體意識教育一體化研究
- 巖土工程勘察課件0巖土工程勘察
- 《腎上腺腫瘤》課件
- 2024-2030年中國典當行業(yè)發(fā)展前景預(yù)測及融資策略分析報告
- 《乘用車越野性能主觀評價方法》
- 幼師個人成長發(fā)展規(guī)劃
- 2024-2025學年北師大版高二上學期期末英語試題及解答參考
- 批發(fā)面包采購合同范本
- 乘風化麟 蛇我其誰 2025XX集團年終總結(jié)暨頒獎盛典
- 2024年大數(shù)據(jù)分析公司與中國政府合作協(xié)議
- 一年級數(shù)學(上)計算題專項練習匯編
評論
0/150
提交評論