博弈論入門 Bash 、Nim 、Wythoff's Game結論及c++代碼實現

来源:https://www.cnblogs.com/noobimp/archive/2019/01/22/10306311.html
-Advertisement-
Play Games

SG函數先不說,給自己總結下三大博弈。和二進位及黃金分割聯繫密切,數學真奇妙,如果不用考試就更好了。 1.Bash Game:n個物品,最少取1個,最多取m個,先取完者勝。 給對手留下(m+1)的倍數肯定獲勝。若n%(m+1)==0,先手必敗。 51nod裸題:1066 2.Nim Game:n堆物 ...


SG函數先不說,給自己總結下三大博弈。和二進位及黃金分割聯繫密切,數學真奇妙,如果不用考試就更好了。

1.Bash Game:n個物品,最少取1個,最多取m個,先取完者勝。

給對手留下(m+1)的倍數肯定獲勝。若n%(m+1)==0,先手必敗。

51nod裸題:1066

 1 #include <iostream>
 2 #include <cstdio>
 3 using namespace std;
 4 int main(){
 5     int t; cin>>t;
 6     int n,k;
 7     while(t--){
 8         cin>>n>>k;
 9         if(n%(k+1)==0)  puts("B");
10         else  puts("A");
11     }
12     return 0;
13 }

 

 

2.Nim Game:n堆物品,取某一堆的若幹個,至少取一個,多者不限,先取完者勝。

在這個博弈中,對任何奇異局勢 (a,b,c....n),都有a^b^...^n==0。

所以直接檢測給的局勢,若是奇異局,先手必敗。

如何將(a,b,c)轉化成奇異局:將c變為a^b,即c -= a^b(^是異或)

51nod裸題:1069

 1 #include <iostream>
 2 #include <cstdio>
 3 using namespace std;
 4 int main(){
 5     int a[1005]={0};
 6     int ans=0;
 7     int n; cin>>n;
 8     for(int i=0;i<n;i++){
 9         cin>>a[i];
10         ans^=a[i];
11     }
12     if(ans)  puts("A");
13     else  puts("B");
14     return 0;
15 }

 

 

3.Wythoff's Game:兩堆若幹個,輪流從某一堆取任意個或同時從兩堆取同樣多任意個,最少一個,多者不限。先取完者勝。

局勢:(ak,bk) 

前幾個奇異局:(0,0)  (1,2)  (3,5)  (4,7)  (6,10)  (8,13)  (9,15)  (11,18)  (12,20)……

1.發現差值遞增,且局面中第一個值為前面局面中沒有出現過的數字的第一個數,且所有自然數都會出現。

2.再找規律:第一個值=(int) (差值*1.618) 而1.618 = ( sqrt(5)+1 )/2

3.所以,只要ak == (int) (bk - ak) * ( sqrt(5) + 1 ) / 2 先手必輸,否則先手必勝

51nod裸題:1072

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cmath>
 4 using namespace std;
 5 double c=(sqrt(5)+1)/2;
 6 int main(){
 7     int t; cin>>t;
 8     int ak,bk;
 9     while(t--){
10         cin>>ak>>bk;
11         if(ak>bk) swap(ak,bk);
12         int n=(bk-ak)*c;
13         if(ak==n)  puts("B");
14         else  puts("A");
15     }
16     return 0;
17 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 2019-01-22 22:50:05 centos7預設安裝的是python2.7,然而python2基本上要淘汰了,所以有必要安裝最新的python3 python,g++這些工具一般安裝在/usr/bin目錄里 通過指令ll python*可以看到python指向的是python2.7 我們要 ...
  • Python3新特性 類型註解 以及 點點點 ... + Python3 的 新特性 + Python 是一種動態語言,變數以及函數的參數是 不區分類型 的 + 在 函數中使用類型註解 相當於 給 形參的 類型 設置了一個備註 + 使用 PyCharm 編寫python代碼時 函數調用會有預設參數的 ...
  • 【問題描述】 輸出1到n之間所有不重覆的排列,即1到n的全排,要求所產生的任一數列不含有重覆的數字. 【代碼展示】 #include<iostream>using namespace std;int a[100],b[100];void quanpai(int index,int n){ //遞歸邊 ...
  • 1、二維數組的定義:當數組中每個元素帶有兩個下標時,稱這樣的數組為二維數組。在邏輯上可以把二維數組看成是一個具有行和列的表格或一個矩陣。 一般形式:類型說明符 數組名[常量表達式1][常量表達式2]; 例:定義a為3*4(3行4列)的數組,b為5*10(5行10列)的數組。 在記憶體中的表達: 例如: ...
  • 在併發編程中,對於共用資源的使用需要確保絕對的安全性。除了利用鎖機制之外,還有一種無鎖的概念。所謂無鎖,就是假定在併發情況下,對於共用資源的訪問沒有衝突,線程可以一直不停的運行,無需阻塞,如果產生衝突,則使用CAS演算法確保全全性。Java在很多併發代碼中都使用了這種演算法。 CAS演算法的核心參數如下: ...
  • 要使用python中的串口,可以下載pywin32-224-cp36-cp36m-win_amd64.whl去安裝或者pip install去安裝。 調試下來,有一點很不爽,讀取read()數據的timeout時間最小單位是秒,這對應很頻繁的讀取使用,很浪費時間。如果不設置這個時間我在有些串口設備上 ...
  • spring boot 2.0 整合 elasticsearch NoNodeAvailableException ...
  • 【問題描述】 已知三個素數的和為 n ,正整數 n 由鍵盤輸入,計算並輸出這三個素數乘積的最大值。 【代碼展示】 # include<iostream>using namespace std;int sushu(int x){ for(int i=2;i<=x/2;i++){ // 如果是合數,返回 ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...