扯在前面

我们老师刚讲过的题目,很考验思维,本蒟蒻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. Atcoder abc187 F Close Group(动态规划)

    Atcoder abc187 F Close Group 题目 给出一张n个点,m条边的无向图,问删除任意数量的边后,留下来的最少数量的团的个数(\(n \le 18\) ) 题解 核心:枚举状态+动 ...

  2. Java基础经典案例

    案例列表 01减肥计划switch版本 02减肥计划if版本 03逢七跳过 04不死神兔 05百钱白鸡 06数组元素求和 07判断两个数组是否相同 08查找元素在数组中的索引 09数组元素反转 10评 ...

  3. 将WCF迁移到gRPC

    使用protobuf-net.Grpc将WCF服务迁移到gRPC非常简单.在这篇博文中,我们将看看它到底有多简单.微软关于将WCF服务迁移到gRPC的官方指南只提到了Gooogle.Protobuf方 ...

  4. python第一节:变量及数据类型

    一.变量 1.什么是变量 变:即为变化的事物 量:即为事物当前的状态 2.为什么用变量 变量可以方便的记录事物当前状态,在后面随时可以调出使用 3.怎么用变量 变量使用前需要先进行赋值(记录状态) 赋 ...

  5. 10分钟搞定让你困惑的 Jenkins 环境变量

    前言 Jenkins, DevOps 技术栈的核心之一,CI/CD 离不开编写 Pipeline 脚本,上手 Jenkins ,简单查一下文档,你就应该不会被 agent,stages,step 这类 ...

  6. 杭电OJ----1097:一个难题(c++)

    问题描述 lcy给feng5166,lwg,JGShining和Ignatius带来了一个难题:给了a和b,如何知道a ^ b.每个人都反对这个BT问题,所以lcy使问题比开始容易. 这个难题描述了: ...

  7. MySQL中in('5,6,7')只取第一个id为5对应的数据的思考

    通过阅读本文你可以更好的理解两个知识点: 1.#{}与${}在实际项目中的使用,避免在项目中使用不当造成不可预知的Bug; 2.MySQL中in里面如果是字符串的话,为什么只取第一个对应的数据,eg: ...

  8. python3实现计算器

    实验内容 1.简单计算器的设计 请设计简单的"加减乘除"计算器并从键盘上输入数据进行计算 数字的加减乘除,input返回的结果是str类型的,通过截取字符串中的运算符,来提取数字, ...

  9. (二)数据源处理1-configparser读取.ini配置文件

    import osimport configparsercurrent_path =os.path.dirname(__file__)#获取config当前文件路径config_file_path = ...

  10. 【Java】变量

    变量 文章目录 变量 1.变量的概念 2.变量的三要素 3.变量的使用应该注意什么? 4.变量的声明和赋值.使用的语法格式? 5.code 1.变量的概念 变量的作用:变量用来存储数据. 变量的本质: ...