P1488 肥貓的游戲

来源:http://www.cnblogs.com/zwfymqz/archive/2017/06/16/7028053.html
-Advertisement-
Play Games

題目描述 野貓與胖子,合起來簡稱肥貓,是一個班的同學,他們也都是數學高手,所以經常在一起討論數學問題也就不足為奇了。一次,野貓遇到了一道有趣的幾何游戲題目,便拿給胖子看。游戲要求在一個有n個頂點凸多邊形上進行,這個凸多邊形的n-3條對角線將多邊形分成n-2個三角形,這n-3條對角線在多邊形的頂點相交 ...


題目描述

野貓與胖子,合起來簡稱肥貓,是一個班的同學,他們也都是數學高手,所以經常在一起討論數學問題也就不足為奇了。一次,野貓遇到了一道有趣的幾何游戲題目,便拿給胖子看。游戲要求在一個有n個頂點凸多邊形上進行,這個凸多邊形的n-3條對角線將多邊形分成n-2個三角形,這n-3條對角線在多邊形的頂點相交。三角形中的一個被染成黑色,其餘是白色。雙方輪流進行游戲,當輪到一方時,他必須沿著畫好的對角線,從多邊形上切下一個三角形。切下黑色三角形的一方獲勝。胖子一看覺得確實很有趣,不如就一起玩玩吧。假設游戲由野貓先開始,那麼野貓是否有必勝的策略呢?請寫一個程式幫助野貓算一算。

輸入輸出格式

輸入格式:

第一行為一個整數n(4<=n<=50000),表示多邊形的頂點數,多邊形的頂點由0至n-1順時針標號。接著的n-2行描述組成多邊形的三角形。第i+1行(1<=i<=n-2)有三個空格分隔的非負整數a、b、c,它們是第i個三角形的頂點編號。第一個給出的三角形是黑色的。

輸出格式:

只有一行,倘若野貓有必勝策略,輸出JMcat Win;否則,輸出PZ Win。(註意大小寫和空格)

輸入輸出樣例

輸入樣例#1:
6
0 1 2
2 4 3
4 2 0
0 5 4
輸出樣例#1:
JMcat Win

說明

各個測試點1s

如果連接一個多邊形中任意兩點的線段都完全包含於這個多邊形,則稱這個多邊形為凸多邊形。

 

 

這題有bug啊,,

5
0 1 4
1 2 3
1 4 3

題解里的程式跑出來的結果是不一樣的

而且我感覺自己寫的對啊,,結果為啥70分,,,

 1 include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<algorithm>
 6 using namespace std;
 7 int read(int & n)
 8 {
 9     char c='-';int x=0;
10     while(c<'0'||c>'9')c=getchar();
11     while(c>='0'&&c<='9')
12     {
13         x=x*10+(c-48);
14         c=getchar();
15     }
16     n=x;
17 }
18 int n;
19 int a[4];
20 int main()
21 {
22     read(n);
23     read(a[1]);read(a[2]);read(a[3]);
24     sort(a+1,a+4);
25     if(n%2==0)
26         printf("JMcat Win");
27     else if(((a[3]-a[2])==(a[2]-a[1])))
28         printf("JMcat Win");
29     else
30         printf("PZ Win");
31     return 0;
32 }
感覺寫的對但是70分

 

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<algorithm>
 6 using namespace std;
 7 int read(int & n)
 8 {
 9     char c='-';int x=0;
10     while(c<'0'||c>'9')c=getchar();
11     while(c>='0'&&c<='9')
12     {
13         x=x*10+(c-48);
14         c=getchar();
15     }
16     n=x;
17 }
18 int n;
19 int a[4];
20 int main()
21 {
22     read(n);
23     read(a[1]);read(a[2]);read(a[3]);
24     sort(a+1,a+4);
25     if(n%2==0)
26         printf("JMcat Win");
27     else 
28     {
29         int count = 0;
30         if (abs(a[1]-a[2])==1) count++;
31         if (abs(a[1]-a[3])==1) count++;
32         if (abs(a[2]-a[3])==1) count++;
33         if (count==2) 
34         cout<<"JMcat Win\n";
35         else
36         printf("PZ Win");
37     }
38     
39     return 0;
40 }

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 在計劃任務中經常可以看到。例如我們公司的計劃任務舉例: 對於& 1 更準確的說應該是文件描述符 1,而1標識標準輸出,stdout。對於2 ,表示標準錯誤,stderr。2>&1 的意思就是將標準錯誤重定向到標準輸出。這裡標準輸出已經重定向到了 /dev/null。那麼標準錯誤也會輸出到/dev/n ...
  • 公司所用計劃任務均是大概這樣子的: 可以看到把輸出與標準錯誤進行重定向到空設備了,這樣做是有一定原因的。查閱了一些資料,在這裡描述一下: 1.ssh登陸伺服器2.新建一個php文件test.php,代碼如下: 3.用以下命令執行test.php程式 查看 /tmp/test.txt 文件的內容為14 ...
  • 題目描述 牛牛最近迷上了一種叫鬥地主的撲克游戲。鬥地主是一種使用黑桃、紅心、梅花、方片的A到K加上大小王的共54張牌來進行的撲克牌游戲。在鬥地主中,牌的大小關係根據牌的數位表示如下:3<4<5<6<7<8<9<10<J<Q<K<A<2<小王<大王,而花色並不對牌的大小產生影響。每一局游戲中,一副手牌 ...
  • Java的記憶體分配上,主要分4個塊!一塊是用來裝代碼的,就是編譯的東西。一塊是用來裝靜態變數的,例如用static關鍵字的變數,例如字元串常量。一塊是stack,也就是棧,是用來裝變數和引用類型的!但區別在於,裝了變數以後,變數上是有值的,而引用類型本身在stack上是沒有值的。一塊是heap,也就 ...
  • 今天使用ab(apacheBench)測試了一下beego的性能。 3Kbytes動態文件,在i3上可以達到每秒1W次響應的性能。但是在測試靜態文件時,beego出現了問題。ab測試參數:100次請求,併發數5。問題表現:70%的請求直接失敗,連接斷開。按道理來說,一個web server框架,靜態 ...
  • 整個項目只有四張表 book-書籍主表,記錄書籍的詳情信息,包括類別,作者描述等 type-類別表,書籍類別管理 menu-目錄章節表 properties-配置表 book表是書籍主表 code:用於圖書code記錄,可認為該欄位能確定圖書唯一 typeId:關聯type表主鍵id,標識圖書類別 ...
  • 之所以將抽象類和介面放在一起做筆記,是因為他們之間很難區分又各自獨立。在學習完Java程式設計的三大特點(封裝、繼承、多態)之後,我最大的收穫是,慢慢理解了Java語言這種面向對象程式設計的優越性,它既能保持自身獨立性又在不斷進化、發展的。如果說封裝和繼承是實現Java多態性的基礎,那我個人覺得抽象 ...
  • <?php // 暫不支持斷點續傳 // $url = 'http://www.mytest.com/debian.iso'; 不知道為何獲取本地文件大小為0 $url = 'http://192.168.8.93/download/vm-672/18/0.vmdk'; $file = basena... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...