扯在前面

我们老师刚讲过的题目,很考验思维,本蒟蒻WA了十发才过,然后看到题解里只是指出了特殊情况没多解释,可能有人看不懂,特来分享一下

首先题目就很有意思,思考的过程也很有趣,想把所有情况思考全思考对是件很不容易的事


正文

题意:

两人取n堆数量不定的石子,当某一方取完后剩下了两堆一样的或本轮无石子可取(当前石子数为0),则失败。问给出石子各堆的数量,求先手胜还是后手胜。

分析:

首先,站在博弈论的角度,或者说把自己当做参与者,思考一下什么情况下是对自己最有利的,也就是说什么情况下自己必胜

然后抱着这样的心态,我们可以手玩几组样例。

我们就可以知道

  1. 若场上有两堆石子,一堆数量多一堆数量少,那我们宁可取少的,因为那样出现取完后两堆相同的概率最低;

  2. 当两边都这样想时,就会不停取,一直取到一种极端情况,那就是每堆石子的数量是以一递增的,那时游戏就结束了,因为不管再怎么取,都会出现两堆相同数量的石子(两堆0也是);

  3. 当场上已经有两堆相同的石子时,下一次操作的人必取两堆其中之一,因为他如果不取,取完后这两堆相同,他就输了;

  4. 若刚刚那人取完后,场上仍存在两堆相同的,他还是输了,即当时还存在一堆石子数量是刚刚那两堆数量减一或场上存在另外两堆以上数量相同但与这两堆数量不同的石子

  5. 若场上存在三堆及以上石子时,先手无论怎么取,都会输,原因同上

然后可得出情况如下可以判断某方必胜:

  1. 场上石子数已经是按1递增的
  2. 场上存在三堆及以上石子相等
  3. 场上存在两堆石子相同且还有一堆石子数比这两堆少一
  4. 场上存在两堆0

这些先判断出来,剩下的统计原来的石子总数与极端情况的石子总数之差,若为偶数则后手赢,反之则先手赢

代码

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<cstdlib>
#include<queue>
#include<algorithm>
#define maxn 1000100 using namespace std; int n,a[maxn],tot,cnt,js; int main(){
scanf("%d",&n);
// if(n==1 &&a[1]==0){
// cout<<"cslnb";
// return 0;
// }
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
tot+=a[i];
}
sort(a+1,a+n+1);
for(int i=1;i<=n;i++){
if(a[i]==a[i+1]) js++;
}
if(js>=2){
cout<<"cslnb";//有两堆以上一样的时后手必赢
return 0;
}
if(js==1){
for(int i=1;i<=n;i++){
if((a[i]==a[i+1] &&a[i-1]+1==a[i] && i!=1) ||(a[i]==a[i+1] &&a[i]==0)){
cout<<"cslnb";//此时先手无所下手,后手赢
return 0;
}
}
}
// if(n==2 &&((a[1]==1&&a[2]==0) ||(a[2]==1 &&a[1]==0))){
// cout<<"sjfnb";
// return 0;
// }
for(int i=1;i<=n;i++){
cnt+=i;
}
cnt-=n;
if(tot-cnt==0){
cout<<"cslnb";
return 0;
}
if((tot-cnt)%2==0) cout<<"cslnb";
else cout<<"sjfnb";
return 0;
}

请批评指正

CF1190B的更多相关文章

  1. 题解 CF1190B 【Tokitsukaze, CSL and Stone Game】

    思路: 首先题目告诉我们,一次只能删去一个石子.当然有翻译时会注意,但是看英文题时总是容易忽略.. 先排序. 然后,你会发现,有些情况是一开始就输的,具体情况如下: 有两个 两个相等非零数.(a[x] ...

随机推荐

  1. [LeetCode]313. Super Ugly Number超级丑数,丑数系列看这一道就行了

    丑数系列的题看这一道就可以了 /* 和ugly number2差不多,不过这次的质因子多了,所以用数组来表示质因子的target坐标 target坐标指的是这个质因子此次要乘的前任丑数是谁 */ pu ...

  2. java数组之排序

    /** * String排序算法依据<b>词典编排顺序排序</b><br> * 所以大写字母开头的词都放在前面输出,之后才是小写之母开头的词 *@date:2018 ...

  3. 史上最全的pycharm快捷键!快进来点个收藏吧

    Alt+Enter 自动添加包 Ctrl+t SVN更新 Ctrl+k SVN提交 [编辑类:](https://link.zhihu.com/?target=https://www.jianshu. ...

  4. 申请免费域名并配置DNS解析及CDN加速

    标题: 申请免费域名并配置DNS解析及CDN加速 作者: 梦幻之心星 sky-seeker@qq.com 标签: [#申请,#免费,#域名,#DNS解析,#CDN加速,#子域名] 目录: [网站] 日 ...

  5. dede 织梦的安装 出现dir

    安装dede系统.(如果您已经安装,请跳过本步.)直接运行:http://您的域名/install如果没有出现该页面,而是出现了一个空白页面写着dir 那么请删除install文件夹中的 instal ...

  6. 风炫安全WEB安全学习第十八节课 使用SQLMAP自动化注入(二)

    风炫安全WEB安全学习第十八节课 使用SQLMAP自动化注入(二) –is-dba 当前用户权限(是否为root权限) –dbs 所有数据库 –current-db 网站当前数据库 –users 所有 ...

  7. Ubuntu 一直要求依赖的错误

    今天笔者在windows上装linux双系统,选用的ubuntu,因为第> 一次用,所以出现了这个问题. 如题,安装个gcc一直要求我要装依赖,如图 接下来我又开始一个个安装那些依赖,比如 su ...

  8. DockerFile关键字相关作用以及解释

    Dockerfile 关键字 作用 备注 FROM 指定父镜像 指定dockerfile基于那个image构建 MAINTAINER 作者信息 用来标明这个dockerfile谁写的 LABEL 标签 ...

  9. 输入12V,输出12V的限流芯片

    随着手机充电电流的提升,和设备的多样化,USB限流芯片就随着需求的增加而越来越多,同时为了更好的保护电子设备,需要进行一路或者多路的负载进行限流. USB限流芯片,5V输入 1, PW1502,常使用 ...

  10. Python入门之修改jupyter启动目录

    [导读]在给大家分享知识的过程中,我们也会分享一些小技巧,能够帮助大家在学习过程中有更好的体验.之前我们给大家分享了anaconda安装教程以及jupyter notebook使用方法,今天我们为大家 ...