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

coreBugZJ

此 blog 已棄。

POJ 1067 取石子游戲

  1/*
  2POJ 1067 取石子游戲
  3
  4
  5----問題描述:
  6
  7有兩堆石子,數量任意,可以不同。游戲開始由兩個人輪流取石子。游戲規定,每次有兩種不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在兩堆中同時取走相同數量的石子。最后把石子全部取完者為勝者。現在給出初始的兩堆石子的數目,如果輪到你先取,假設雙方都采取最好的策略,問最后你是勝者還是敗者。
  8
  9
 10----輸入:
 11
 12輸入包含若干行,表示若干種石子的初始情況,其中每一行包含兩個非負整數a和b,表示兩堆石子的數目,a和b都不大于1,000,000,000。
 13
 14
 15----輸出:
 16
 17輸出對應也有若干行,每行包含一個數字1或0,如果最后你是勝者,則為1,反之,則為0。
 18
 19
 20----樣例輸入:
 21
 222 1
 238 4
 244 7
 25
 26
 27----樣例輸出:
 28
 290
 301
 310
 32
 33
 34----分析:
 35
 36(轉自網上,略有修正)
 37
 38大致看完題目,想當然就知道這是一道博弈論的問題,最容易想的就是直接用博弈論的必敗、必勝態進行動態規劃求解。但是樸素的動態規劃是 O(N * M) 的,如果做一些優化可能可以過掉 RQNOJ 的題目,但是對于 POJ 1067 來說就完全無能為力。所以我們嘗試分析數據,看看有沒有什么規律(以下用 (a, b) 表示兩堆石子的個數,即游戲中的一個狀態)。
 39
 40列舉了幾個狀態之后容易發現,必勝態的數目比必敗態要多很多,所以我們先手工求出前幾個必敗態:
 41
 42(1, 2)、(2, 1)、(3, 5)、(5, 3)、(4, 7)、(7, 4)、(6, 10)、(10, 6)……
 43
 44首先回顧必勝態和必敗態的樸素求法:
 45
 46定理 0:一個狀態是必敗態,當且僅當它的所有后繼狀態都是必勝態;而一個狀態是必勝態,只要它的后繼狀態有一個以上的必敗態即可。
 47
 48證明略去。
 49
 50容易發現下面的定理:
 51
 52定理 1:(a,b) 和 (b, a) 的勝負性是相同的(a <> b)。
 53
 54證明:如果 (a, b) 是必勝態,那么將必勝策略中所有的操作,對第一堆的變為第二堆,對第二堆的變為第一堆,就構成 (b, a) 的必勝策略
 55
 56定理 2:若 (a, b) 是必敗態,則對于所有的 x <> a 和 y <> b,(x, b) 和 (a, y) 是必勝態。
 57
 58證明:
 59
 60對于 x > a 和 y > b,不管是哪一種情況,總可以從 x 堆或 y 堆中取出一定量的石子使當前狀態變為必敗態 (a, b),由定理 1,(x, b) 和 (a, y) 為必勝態。
 61
 62對于 x < a 和 y < b,不管是哪一種情況,如果 (x, b) 或 (a, y) 是必敗態的話,由上述可得 (a, b) 是必勝態,矛盾。故 (x, b) 和 (a, y) 均為為必勝態。
 63
 64定理 3: 若 (a, b) 是必敗態,則對于所有的 d > 0,(a + d, b + d) 是必勝態。
 65
 66證明:
 67
 68與定理 2 類似。
 69
 70定理 4:在所有的必敗態中,每個數字恰巧出現一次。
 71
 72證明:
 73
 74有了定理 1,對于對稱的狀態我們只需要處理其中一個,而兩個數不會相同(相同的狀態必然是必勝態),于是我們把每個狀態中較小的數字放在前面,每行寫一個狀態,去掉括號并按照升序排列每行的第一個數,就構成了如下的矩陣:
 75
 761  2
 77
 783  5
 79
 804  7
 81
 826  10
 83
 84……
 85
 86觀察這個矩陣,我們又可以得到新的定理:
 87
 88定理 5:矩陣中每行第一個數恰巧是前面每一行中沒有出現過的最小正整數。
 89
 90證明:
 91
 92由定理 4,矩陣中每個數字恰巧出現一次,而按照這個矩陣的定義,第二列的數總比同行第一列大,第一列又按照升序排列,所以每一行的第一個數正好為前面每一行中沒有出現過的最小正整數。
 93
 94定理 6:矩陣第 i 行的第二個數正好為第一個數加上 i
 95
 96證明:
 97
 98用數學歸納法。
 99
1001) 對于第一行顯然成立
101
1022) 若對于前 i - 1 行均成立,則所有的 (a[p], a[p] + p) (a[p] 為第 p 行第一個數,p < i) 均為必敗態,那么考察第 i 行的狀態 (a[i], a[i] + delta)。容易看出 delta >= i,因為如果 delta < i,一定可以通過一次操作變為前面出現過的必敗態,那么這個狀態就是必勝態。下面由 delta >= i,我們來說明 delta = i。
103
104首先,我們考慮從第一堆中取出 p 個石子,得到狀態 (a[i] - p, a[i] + delta),由定理 5,比 a[i] 小的數都在之前出現過,若 a[i] - p 出現在某一行的第一列,由于存在必敗態 (a[i] - p, a[i] - p + d) (d < delta),故 (a[i] - p, a[i] + delta) 一定為必勝態(定理 2);若 a[i] - p 出現在某一行的第二列,由于第一列是單增的,因而其對應的第一列數必小于 a[i] + delta,故而也可推出其狀態為必勝態。
105
106對于從兩堆石子中取出相同數目的情況與之類似,容易看出一定為必勝態。
107
108于是,(a[i], a[i] + delta) 狀態的勝負性只與狀態 (a[i], a[i] + d) (d < delta) 有關。不難看出,delta = i 時恰為必敗態,因為不論從第二堆中取出多少個石子,作為另一堆的第一堆石子并沒有在之前出現過,所以得到的一定是一個必勝態,因而 (a[i], a[i] + delta) 為必敗態,由定理 2 及定理 4 可得,原命題成立。即矩陣中第 i 行第二列的數等于同行第一列的數加上 i。
109
110
111這時,我們所有的問題都轉化到了矩陣上,只要能通過合適的方法表示出這個矩陣,我們就可以很好地解決原問題。
112
113下面的過程可能需要比較高的數學技巧,首先給出我們需要的一個重要定理([x] 表示 x 的整數部分,{x} 表示 x 的小數部分,即 {x} = x - [x]):
114
115定理 7(Betty 定理):如果存在正無理數 A, B 滿足 1/A + 1/B = 1,那么集合 P = { [At], t ∈ Z+}、Q = { [Bt], t ∈ Z+} 恰為集合 Z+ 的一個劃分,即:P ∪ Q = Z+,P ∩ Q = ø。
116
117證明:暫時略去,將來補充。
118
119考慮到 Betty 定理中“恰為 Z+ 的劃分”這一說,這意味著,Z+ 中的每個數都恰好出現一次,這與上述矩陣的性質十分吻合。于是我們猜想每一行第一列的數滿足 [Φi] 的形式。
120
121于是我們得到每一行第二列的數為 [Φi] + i = [Φi + i] = [(Φ + 1)i]
122
123我們的目的是要讓 Z+ 中每個數都在這個矩陣中出現,于是考慮到 Betty 定理的條件,Φ 和 (Φ + 1) 應滿足 1/Φ + 1/(Φ + 1) = 1。解這個方程,我們得到 Φ = (sqrt(5) + 1) / 2,于是 Φ + 1 = (sqrt(5) + 3) / 2。
124
125Φ 恰為黃金分割比,這是多么令人驚奇的結論!
126
127于是應用 Betty 定理,我們得到最終我們需要的定理:
128
129定理 8:上述矩陣中每一行第一列的數為 [Φi],第二列的數為 [(Φ + 1)i],其中 Φ = (sqrt(5) + 1) / 2 為黃金分割比。
130
131證明:由 Betty 定理顯然得證。
132
133 
134
135有了定理 8,代碼的實現就十分簡單了,由于是數學算法,總復雜度為 O(1)。至此,本題完美解決。
136
137
138總結:遇到這樣困難的題目時,我們不應該輕言放棄。而應該仔細分析題目隱含的信息,學會分析和轉化問題,從而找到問題的突破口,一舉殲滅問題。
139
140
141*/

142
143
144#include <iostream>
145#include <cstdio>
146#include <cmath>
147
148using namespace std;
149
150int main() {
151        int a, b, d, t;
152        while ( 2 == scanf( "%d%d"&a, &b ) ) {
153                if ( a > b ) {
154                        t = a;
155                        a = b;
156                        b = t;
157                }

158                d = b - a;
159                t = floor( d * ( sqrt(5.0+ 1 ) / 2 );
160                puts( (t == a) ? "0" : "1" );
161        }

162        return 0;
163}

164

posted on 2012-06-04 16:05 coreBugZJ 閱讀(5488) 評論(0)  編輯 收藏 引用 所屬分類: ACMAlgorithmMathematics課內作業

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲韩国日本中文字幕| 日韩亚洲一区二区| 一区二区不卡在线视频 午夜欧美不卡在 | 午夜精品福利一区二区蜜股av| 国产欧美一区二区色老头| 久久精品人人做人人爽| 亚洲午夜久久久| 亚洲一区二区三区中文字幕| 亚洲精品一品区二品区三品区| 女仆av观看一区| 欧美在线视频在线播放完整版免费观看| 亚洲精品一区中文| 揄拍成人国产精品视频| 国产亚洲精品一区二555| 国产日产欧美精品| 欧美劲爆第一页| 宅男噜噜噜66一区二区66| 亚洲大胆av| 99精品欧美一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 午夜国产欧美理论在线播放| 亚洲一区网站| 久久激情中文| 亚洲免费高清| 午夜精品一区二区三区电影天堂| 乱人伦精品视频在线观看| 男男成人高潮片免费网站| 国产精品久久久久高潮| 伊大人香蕉综合8在线视| 亚洲一区国产一区| 欧美粗暴jizz性欧美20| 亚洲精品中文字| 久久精品国产91精品亚洲| 欧美网站在线| 亚洲理论电影网| 久久99在线观看| 9久re热视频在线精品| 久久精品亚洲| 欧美精品v国产精品v日韩精品| 在线观看91精品国产麻豆| 在线午夜精品自拍| 亚洲免费观看高清完整版在线观看熊| 香蕉久久一区二区不卡无毒影院| 欧美日韩另类一区| 国产精品任我爽爆在线播放 | 久久成人18免费观看| 欧美激情视频在线免费观看 欧美视频免费一 | 久久尤物电影视频在线观看| 亚洲欧美国产毛片在线| 久久精品亚洲一区二区三区浴池| 国产欧美日韩精品在线| 久久久噜噜噜久噜久久| 国产综合色一区二区三区| 欧美激情一区二区三区成人| 欧美丝袜一区二区| 久久久久久久久伊人| 99国产精品视频免费观看| 久久精品成人一区二区三区| 欧美在线日韩在线| 国产一级精品aaaaa看| 欧美中文字幕在线观看| 蜜桃av一区二区三区| 一色屋精品视频在线看| 亚洲视频在线观看| 国产精品久久二区| 亚洲欧美日韩精品久久亚洲区| 亚洲国产精品成人一区二区 | 久久精品盗摄| 久久免费视频网| 亚洲视频一区二区免费在线观看| 免费成人黄色av| 在线观看国产日韩| 免费日韩成人| 欧美成人免费网站| 亚洲另类一区二区| 99www免费人成精品| 欧美揉bbbbb揉bbbbb| 亚洲制服丝袜在线| 亚洲欧美一区二区激情| 国产亚洲精品高潮| 美女黄色成人网| 欧美国产日韩一区二区三区| 一区二区高清视频| 亚洲影院污污.| 在线欧美视频| 亚洲日本一区二区| 欧美私人啪啪vps| 久久黄色影院| 美女国产一区| 日韩视频精品| 亚洲字幕在线观看| 一区在线视频观看| 亚洲人被黑人高潮完整版| 欧美午夜在线| 久久久久久亚洲精品不卡4k岛国| 美日韩精品视频| 亚洲无限av看| 久久综合网络一区二区| 亚洲午夜伦理| 欧美在线精品免播放器视频| 亚洲国产一区二区a毛片| 一卡二卡3卡四卡高清精品视频| 国产一区二区高清| 亚洲国产欧美国产综合一区| 国产精品国产三级国产普通话99| 久久最新视频| 国产精品黄视频| 免费成人激情视频| 国产精品爽黄69| 欧美激情成人在线| 日韩一级片网址| 曰本成人黄色| 中国女人久久久| 91久久综合亚洲鲁鲁五月天| 国产老女人精品毛片久久| 欧美一区二区三区男人的天堂 | 日韩一区二区精品视频| 狠狠色伊人亚洲综合成人| 99re亚洲国产精品| 亚洲国产综合视频在线观看| 亚洲香蕉网站| 99视频精品| 久久在线免费观看视频| 欧美伊久线香蕉线新在线| 欧美手机在线| 日韩一区二区久久| 日韩亚洲国产精品| 美女爽到呻吟久久久久| 久久久夜色精品亚洲| 国产精品网站在线| 99精品视频免费全部在线| 亚洲精品九九| 欧美成黄导航| 你懂的视频一区二区| 国产一区二区三区日韩| 欧美一区影院| 国产精品激情| 亚洲一区二区欧美| 亚洲欧美日韩另类| 欧美三级在线| 在线午夜精品| 亚洲欧美日本精品| 久久aⅴ国产紧身牛仔裤| 欧美伊人久久大香线蕉综合69| 国产精品激情偷乱一区二区∴| 亚洲精品免费看| 99精品久久| 欧美日韩在线播放一区二区| 99re成人精品视频| 亚洲午夜在线观看视频在线| 欧美激情黄色片| 亚洲电影在线看| 欧美激情自拍| 一区二区三区四区五区精品视频| 欧美日韩免费观看一区二区三区 | 欧美一区二区视频观看视频| 久久国产一二区| 加勒比av一区二区| 欧美v亚洲v综合ⅴ国产v| 亚洲国产精品t66y| 日韩亚洲一区在线播放| 国产精品久久久久999| 欧美一区二区播放| 亚洲成人自拍视频| 午夜国产不卡在线观看视频| 国产性色一区二区| 欧美福利在线| 亚洲欧美影院| 亚洲国产欧美日韩精品| 亚洲深夜影院| 激情欧美一区二区| 欧美经典一区二区三区| 亚洲综合另类| 亚洲国产mv| 亚洲影院高清在线| 欧美日韩免费一区二区三区视频 | 一区二区三区高清| 亚洲欧美日韩直播| 欧美日韩在线综合| 国产日韩亚洲欧美| 欧美亚洲视频一区二区| 91久久久精品| 国产欧美日韩不卡免费| 亚洲人成网站777色婷婷| 伊人久久综合97精品| 久久久视频精品| 欧美一区视频| 国产情人综合久久777777| 99国内精品| 欧美日韩在线视频一区| 欧美成人乱码一区二区三区| 亚洲日本成人女熟在线观看| 欧美日韩国产在线一区| 欧美一区二区成人6969| 亚洲欧美另类国产| 国产精品国产三级国产普通话三级 | 亚洲午夜高清视频| 欧美一区二区三区男人的天堂 | 欧美日韩国产精品专区| 一区二区三区不卡视频在线观看 |