HDU4678_Mine

很有意思,很好的題目。

這樣的,一個n*m的掃雷地圖,告訴你哪些地方是有雷的。一個人如果點在了空白處,那么與其相鄰的(八個方向)的數字以及空白都會遞歸地顯示出來,如果點在數字上面,那么就只會顯示這一個數字。

游戲過程中,誰第一個無法點開一個非雷的格子算輸。

這、、、、其實可以看成是nim博弈問題,但是有一點點點點的不同。

我們由于題目說明了數字的部分不會有重復的,所以我們把一個由空白部分連成的區域看成是一堆石子,那么有的單獨的數字就是一堆石子且只有一顆。

同時我們把所有的空白區域看成是一個石子,這樣問題就轉化為了給你N堆石子,以及每一堆的石子的數量,現在要你求出博弈的結果是先手勝還是后手勝?

由于每次可選擇的可以使一堆中的某一顆石子,也可以是一整堆的石子,所以這與單純的nim博弈是有所區別的。

其實可以這樣來考慮這個問題。

我們分別統計出石子數量為奇數的堆有多少個(x)、石子數為偶數的堆有多少個(y)。

那么其實,除非x和y均為偶數,否則先手必勝。

這樣來理解,其實博弈過程中,必勝者只要一直維護所有的石子數之和為偶數即可。

但是如果是一開始就為偶數偶數的話,那么就是必輸了。

不知道這么理解對不對呢?

?

?

#pragma comment(linker, "/STACK:1024000000,1024000000")
#include <iostream>
#include <cstdio>
#include <cstring>
#define maxn 1010
using namespace std;int a[maxn][maxn],t,n,m,k,xi,yi,ans,cas=0,tot,flag;
bool b[maxn][maxn],vis[maxn][maxn];int dfs(int x,int y)
{if (a[x][y]==-1 || x<1 || x>n || y<1 || y>m) return 0;if (b[x][y]) return 0;b[x][y]=true;if (a[x][y]!=0) return 1;return dfs(x+1,y)+dfs(x-1,y)+dfs(x,y+1)+dfs(x,y-1)+dfs(x-1,y-1)+dfs(x-1,y+1)+dfs(x+1,y-1)+dfs(x+1,y+1);
}int main()
{scanf("%d",&t);while (t--){memset(a,0,sizeof a);memset(b,false,sizeof b);memset(vis,false,sizeof vis);scanf("%d%d%d",&n,&m,&k);tot=0;while (k--){scanf("%d%d",&xi,&yi);xi+=1,yi+=1;vis[xi][yi]=true;}for (int i=1; i<=n; i++)for (int j=1; j<=m; j++){if (vis[i][j]){a[i][j]=-1;continue;}a[i][j]=0;for (int ii=-1; ii<=1; ii++)for (int jj=-1; jj<=1; jj++)if (vis[i+ii][j+jj]) a[i][j]++;}ans=0;for (int i=1; i<=n; i++)for (int j=1; j<=m; j++){if (b[i][j]) continue;if (a[i][j]==0){int tep=dfs(i,j)+1;if (tep&1) ans^=1;else ans^=2;tot++;}
            }for (int i=1; i<=n; i++)for (int j=1; j<=m; j++){if (b[i][j]) continue;if (a[i][j]==-1) continue;b[i][j]=true;ans^=1;tot++;
            }if (ans) printf("Case #%d: Xiemao\n",++cas);else printf("Case #%d: Fanglaoshi\n",++cas);}return 0;
}

?

轉載于:https://www.cnblogs.com/lochan/p/3450189.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/376250.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/376250.shtml
英文地址,請注明出處:http://en.pswp.cn/news/376250.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

pygame只能編寫游戲_游戲框架搭建

游戲框架搭建目標 —— 使用 面相對象 設計 飛機大戰游戲類目標明確主程序職責實現主程序類準備游戲精靈組01. 明確主程序職責回顧 快速入門案例&#xff0c;一個游戲主程序的 職責 可以分為兩個部分&#xff1a;游戲初始化游戲循環根據明確的職責&#xff0c;設計 PlaneGame 類…

周末閱讀:本周熱門文章排行榜

那道不清說不盡的故事 iPhone 的創意并非來自喬布斯一人&#xff0c;其起源可以追溯到 Jony 的設計團隊對多點觸控屏幕的思考和探索&#xff0c;也正是因為對這個技術的看好&#xff0c;在對其在手機上的可行新的不斷測試后&#xff0c;蘋果最后下定決心進軍手機領域。這篇文章…

python3 hash算法使用

python3下的pycryptodome庫 from Crypto.cipher import * if __name__ __main__:message 123#MD5和SHA的用法差不多print("SHA3_512: " SHA3_512.new(message.encode(utf-8)).digest().hex())print("SHA512: " SHA512.new(message.encode(utf-8)).dig…

poj3335 半平面交

題意&#xff1a;給出一多邊形。判斷多邊形是否存在一點&#xff0c;使得多邊形邊界上的所有點都能看見該點。 sol&#xff1a;在紙上隨手畫畫就可以找出規律&#xff1a;按逆時針順序連接所有點。然后找出這些line的半平面交。 題中給出的點已經按順時針排好序了&#xff0c;所…

php進程間通信 yoc_續上篇Swoole多進程數據共享的問題

原因進程作為程序執行過程中資源分配的基本單位&#xff0c;擁有獨立的地址空間,同一進程的線程可以共享本進程的全局變量&#xff0c;靜態變量等數據和地址空間&#xff0c;但進程之間資源相互獨立。由于PHP語言不支持多線程&#xff0c;因此Swoole使用多進程模式&#xff0c;…

JavaBean的規范

&#xff08;1&#xff09;JavaBean 類必須是一個公共類&#xff0c;并將其訪問屬性設置為 public &#xff08;2&#xff09;JavaBean 類必須有一個空的構造函數&#xff1a;類中必須有一個不帶參數的公用構造器&#xff0c;此構造器也應該通過調用各個特性的設置方法來設置特…

linux虛擬機ip修改無效

把一個centos虛擬機移動到另一臺電腦的時候&#xff0c;移動前是靜態ip&#xff0c;移動后發現虛擬機的ip不同了。 由于使用的是NAT&#xff0c;于是就修改了虛擬機的配置&#xff0c;發現虛擬機的ip仍然不是配置文件需要的情況。 可以嘗試命令nmcli con show&#xff0c;如果…

驗證(Verification)與確認(Validation)的差別

驗證(Verification)與確認&#xff08;Validation&#xff09;的差別 說法一&#xff1a; &#xff08;2&#xff09;“驗證(Verification)”的涵義 通過提供客觀證據對規定要求已得到滿足的認定。 &#xff08;2&#xff09;“確認&#xff08;Validation&#xff09;”的涵義…

vscode自動格式化不符合eslint_VsCode(Visual Studio Code)格式化代碼符合EsLint

利用Visual Studio Code ESlint插件&#xff0c;實現自動格式化代碼步驟一&#xff1a;安裝ESlint插件>點擊Extensions或者CtrlShiftX>搜索ESlint>install EsLint步驟二: 重啟VsCode&#xff0c; 發現代碼提示報錯&#xff0c;代碼不符合規范步驟三&#xff1a;鼠標ho…

解讀Google分布式鎖服務

背景介紹 在2010年4月&#xff0c;Google的網頁索引更新實現了實時更新&#xff0c;在今年的OSDI大會上&#xff0c;Google首次公布了有關這一技術的論文。 在此之前&#xff0c;Google的索引更新&#xff0c;采用的的批處理的方式(map/reduce)&#xff0c;也就是當增量數據達到…

使用PHPMailer郵件發不出去

遇到了PHPMailer發不出去郵件的問題&#xff0c;在執行smtpConnect()時失敗了&#xff0c;同樣的配置在其他環境就能發送郵件。 最后發現是dns沒有配置&#xff0c;解析不了郵箱服務器的域名&#xff0c;所以沒發出去。。。。 如果其他語言也遇到了這樣的情況&#xff0c;可以…

PHPcurl抓取AJAX異步內容(轉載)

PHPcurl抓取AJAX異步內容其實抓ajax異步內容的頁面和抓普通的頁面區別不大。ajax只不過是做了一次異步的http請求&#xff0c;只要使用firebug類似的工具&#xff0c;找到請求的后端服務url和傳值的參數&#xff0c;然后對該url傳遞參數進行抓取即可。 利用Firebug的網絡工具 …

做自適應網站專業樂云seo_自適應網站方案品牌樂云seo

自適應網站方案品牌樂云seo&#xff0c;做樂云seo網站推廣哪收錄比較穩定&#xff0c;下面小編從以下幾點詳細介紹一下自適應網站方案品牌樂云seo&#xff1a;一、樂云seo做核心關鍵詞首頁排名技術怎么樣&#xff1f;孔祥永seo做核心關鍵詞到首頁的秘訣就是做好原創內容&#x…

boost windows編譯

執行&#xff1a; &#xff08;1&#xff09;bootstrap.bat &#xff08;2&#xff09;b2 -j4 toolsetmsvc-9.0 linkstatic threadingmulti runtime-linkstatic address-model64 stage --stagedir“D:\Code\boost_1_66_0\lib” debug release toolset:msvc-9.0 使用vs2008編…

必應輸入法產品分析

2013年4月&#xff0c;微軟MSN(中國)宣布推出首款整合搜索體驗的中文云輸入法“必應Bing輸入法”&#xff0c;其前身是“英庫拼音輸入法(于2012年8月發布測試版)” 在此&#xff0c;Fruits小組從宏觀的軟件工程角度和微觀的產品實現細節對必應輸入法進行了考察和分析。 &#x…

這是我第一題AC的線段樹

題目簡述&#xff1a; 有N個整數&#xff0c;Q次操作&#xff0c;每次操作為詢問一個區間[a, b]內數的和(0號操作)或者把一個區間內的數全部加上v(1號操作) 線段樹求解即可。 #include <cstdio> #include <algorithm> using std::min; using std::max; #define L(n…

a頻繁連接不上redis_連接不到redis Caused by:..._慕課問答

redis裝在linux虛擬機上&#xff0c;在xshell上可以成功訪問redis&#xff0c;配了密碼拿了老師完整的代碼作測試&#xff0c;就是訪問失敗&#xff0c;不知道哪里出了問題地址端口密碼都沒錯的&#xff0c;求解org.springframework.data.redis.RedisConnectionFailureExceptio…

抓localhost包 - rawcap

抓localhost包的話用wireshark好像有點麻煩&#xff0c;所以用rawcap RawCap官網 RawCap下載連接 直接運行&#xff0c;首先根據需要選擇監聽相應的網卡&#xff0c;然后再填寫抓包文件保存的名字

持續集成交付CICD:Jira 發布流水線

目錄 一、實驗 1.環境 2.GitLab 查看項目 3.Jira 遠程觸發 Jenkins 實現合并 GitLab 分支 4.K8S master節點操作 5.Jira 發布流水線 一、實驗 1.環境 &#xff08;1&#xff09;主機 表1 主機 主機架構版本IP備注master1K8S master節點1.20.6192.168.204.180 jenkins…

計算幾何_多邊形

判定凸多邊形&#xff1a;頂點凹凸性法 連續三個頂點p1,p2,p3。計算p1p2,p2p3的叉乘&#xff0c;階乘大于0&#xff0c;則表示p3點在線段p1和p2的左側&#xff0c;然后依次計算下一個前后所組成向量的階乘&#xff0c;如果在計算時&#xff0c;出現負值&#xff0c;則此多邊形是…