肥猫吃披萨游戏JAVA,题解 P1488 【肥猫的游戏】

本文探讨了一个涉及几何和策略的游戏问题:两个人轮流从一个N边形中切掉三角形,目标是拿到黑色三角形。通过分析,作者指出当N边形的对角线被切N-2次后,会剩下两个三角形,此时持有黑色三角形的一方将输掉游戏。关键在于(N-2)模2的结果,若为1,则后手PZ获胜,否则先手JMcat获胜。文章提供了一个C++程序来验证这个结论,并给出了特殊情况的判断。
摘要由CSDN通过智能技术生成

这道题目题解与数据太水了!现在给出我的方法。

题意简述:

把一个$N$边形沿着对角线切割,分成$N-2$个三角形,选其中一个三角形为黑色三角形。JMcat先拿,PZ后拿,两人轮流拿走边上的一个三角形,谁能拿走黑三角形谁就是胜者。

思路:分两种情况

第一种如下图:

4d98154e996aff15e5aced1cc760c9b2.png

这一种情况很明显可以直接切到,所以是JMcat获胜。

第二种情况如下图:

a7787d80527cc7b84976cb4ebd1a33b3.png

即黑色三角形在中间的情况,这样的话.....嗯?该怎么办呢?我们模拟切一下,如果两人都按照最优方案切,那么就会出现下图:

f3abc862077a355cf63230a98cf87869.png

唉?这不就是剩下三个三角形,黑色的在中间嘛!那么就是说这一步轮到谁切谁输咯!切完这个三角形就剩2个,所以$(N-2)$就表示切完剩两个三角形后此时共切走多少个三角形。

结论:用$(N-2)$%$2$如果为1即是PZ赢,否则是JMcat赢。

参考程序:

#include

using namespace std;

int n,a,b,c,aa,bb,cc;

void Sort(int &x,int &y,int &z)

{

if(x>y)swap(x,y);

if(x>z)swap(x,z);

if(y>z)swap(y,z);

}

int main()

{

scanf("%d",&n);

for(int i=1;i<=n-2;i++)

{

scanf("%d%d%d",&a,&b,&c);

if(i==1)aa=a,bb=b,cc=c;//记录下黑色三角形的三个顶点编号

}

Sort(aa,bb,cc);//将三个编号从小到大排序,方便判断

if((aa==0&&bb==n-2&&cc==n-1)||(aa+1==bb&&bb+1==cc)){puts("JMcat Win");return 0;}//如果编号两两相差1,就是最外边,注意特判六边形中0 4 5是黑色的,之类的这种最后一个三角形是黑色三角形,是因为编号从0开始

if((n-2)%2==1)puts("PZ Win");else puts("JMcat Win");//这里思路已经说过

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值