一.题目

​ Tokitsukaze, CSL and Stone Game

​ Tokitsukaze和CSL正在玩一些石头游戏。

​ 一开始,有n堆的石头,第i堆石头数记为 \(a_i\),两人轮流操作。 Tokitsukaze先行动。 在每个回合中,玩家选择非空的一堆石头并从中移除一块石头。 如果在操作前每堆都是空的,或者如果在移除石头之后,有两堆(可能是空的)包含相同数量的石头,则该玩家输了。 假设两位球员都采取最优方案,谁将赢得比赛?

​ 考虑一个例子: n = 3,\(a_1\)=2, \(a_2\)=3, \(a_3\)=0.选择空堆是不可能的,因此Tokitsukaze有两种选择:从第一堆和第二堆中拿走一块石头。当他从第一堆拿石头后,\(a_1\)=1, \(a_2\)=3, \(a_3\)=0,这是可行的;当他从第二堆拿石头后,\(a_1\)=2, \(a_2\)=2, \(a_3\)=0,他会立即输掉。因此他只能从第一堆拿石头。

​ 假设两人总是采取最佳方案并且永远不会犯错误,谁将赢得比赛?

​ 请注意,即使最初有两堆的石头数目相同,Tokitsukaze仍然可以进行有效的第一步,只需要在拿走石头后没有两堆的石头数目相同即可。

输入

​ 第一行包含一个整数 n (\(1 ≤ n ≤ 10^5\))代表石堆数

​ 第二行包含 n个 整数 \(a_1,a_2,...,a_n(0≤a_i≤10^9)\)

输出

​ 如果Tokitsukaze赢,打印\(“sjfnb”\);如果CSL赢,打印\(“cslnb”\);请注意,输出字符区分大小写,且没有引号

Examples

input

1
0

output

cslnb

input

2
1 0

output

cslnb

input

2
2 2

output

sjfnb

input

3
2 3 1

output

sjfnb

注意

在第一个例子中,Tokitsukaze不能拿任何石头,所以CSL将获胜。

在第二个例子中,Tokitsukaze只能从第一堆中获取一块石头,然后,即使它们没有石头,这两堆也将拥有相同数量的石头,这意味着CSL将获胜。

在第三个例子中,Tokitsukaze将获胜。 :

  • 首先,Tokitsukaze可以选择第一堆并从那堆中取出一块石头。
  • 然后,CSL只能选择第一堆,因为如果他选择第二堆,他将立即失去。
  • 最后,Tokitsukaze可以选择第二堆,然后CSL将别无选择,只能输。

在第四个例子中,他们在任何时候都只有一个不错的选择,因此Tokitsukaze可以让游戏持续尽可能长的时间并最终获胜。

二.解题思路

首先用数组a来依次存入\(a_i\);

我们可以定义石头数量相同的两堆为一个“pair”。我们来考虑三种情况:

  1. 当初始状态中有两个pair时,那么无论第一个人破坏哪一个pair,都会有两堆的石头数相同,他必输。

  2. 当初始状态中没有pair(即不存在有相同数量的两堆石头):

    ​ 我们先对数组\(a\)进行升序排序。可以发现:

    ​ a.在每人拿走一块石头后,一定有\(a[i]>a[i-1]\)

    ​ b.数组a从0开始存的情况下,一定有第i堆石头数\(a[i-1]>=i-1\).因为第一堆最少为0块,第二堆至少比第一堆多1,即第二堆最少有一块,递推得第\(i\)堆最少有\(i-1\)块石头。

    ​ c.当\(a[0]=0,a[1]=1,...,a[n-1]=n-1\)时,下一个人已经无路可走,我们可以称该状态为必输状态

    ​ d.在pair=0的情况下,任何初始状态都会演变成必输状态

    ​ 因此,当前状态变成必输状态若经过了奇数次操作(即拿走了奇数块石头),第一个人Tokitsukaze赢;而经过了偶数次操作,第二个人CSL赢。

    3.当初始状态中仅有一个pair(即仅存在两堆有相同数量的石头),情况和pair=0类似,对数组a升序排序后任然满足a-c三条规律,不过会出现第一个人连第一步都无法进行的初始状态:

    ​ 记第index堆和第index+1堆有相同的石头数,则a[index]=a[index+1],当a[index-1]=a[index]-1时,当前状态也是一种必输状态,因此需要特判一下,在破坏唯一的pair时,会不会又出现两堆有相同的石头数量。

三.AC代码

#include<bits/stdc++.h>
using namespace std;
int a[100005];
typedef long long LL; int main(){
int n,num=0,index;
LL sum=0,aim=0;
cin>>n;
aim=(LL)n*(LL)(n-1)/2;
for(int i=0;i<n;i++) cin>>a[i];
sort(a,a+n);
for(int i=0;i<n-1;i++){
if(a[i]==a[i+1]){
num++;index=i;
}
}
if(num>=2) {cout<<"cslnb";return 0;}
if(num==0){
for(int i=0;i<n;i++) sum+=(LL)a[i];
if((sum-aim)%2) {cout<<"sjfnb";return 0;}
else {cout<<"cslnb";return 0;}
}
else{
if(a[index]==0) {cout<<"cslnb";return 0;}
if(index==0||a[index-1]!=a[index]-1){
for(int i=0;i<n;i++) sum+=(LL)a[i];
if((sum-aim)%2) {cout<<"sjfnb";return 0;}
else {cout<<"cslnb";return 0;}
}
else cout<<"cslnb";
}
return 0;
}

Codeforces Round #573 (Div. 2) D题题解的更多相关文章

  1. Codeforces Round #612 (Div. 2) 前四题题解

    这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...

  2. Codeforces Round #579 (Div. 3) 套题 题解

    A. Circle of Students      题目:https://codeforces.com/contest/1203/problem/A 题意:一堆人坐成一个环,问能否按逆时针或者顺时针 ...

  3. Codeforces Round #741 (Div. 2)部分题题解

    我果然还是太菜了,就写了两道题....真是水死了.... A The Miracle and the Sleeper 简化题意:给定\(l,r\),求\(a\)%\(b\)的最大值,其中\(r> ...

  4. Codeforces Round #744 (Div. 3) G题题解

    淦,最后一道题没写出来,...还是我太菜了,不过这个题确实比较有趣. G. Minimal Coverage 简化题意:就是你处在坐标轴的0点上,给你一个序列\(a_i\),每次你可以选择向左走\(a ...

  5. Codeforces Round #573 (Div. 1) 差F

    Codeforces Round #573 (Div. 1) E 题意:二维平面上有 n 个点,你可以放至多 m 条直线使得 (0,0) 与每个点的连线至少与一条直线相交.求原点与所有直线的距离最小值 ...

  6. Codeforces Round #378 (Div. 2) D题(data structure)解题报告

    题目地址 先简单的总结一下这次CF,前两道题非常的水,可是第一题又是因为自己想的不够周到而被Hack了一次(或许也应该感谢这个hack我的人,使我没有最后在赛后测试中WA).做到C题时看到题目情况非常 ...

  7. Codeforces Round #713 (Div. 3)AB题

    Codeforces Round #713 (Div. 3) Editorial 记录一下自己写的前二题本人比较菜 A. Spy Detected! You are given an array a ...

  8. Codeforces Round #552 (Div. 3) A题

    题目网址:http://codeforces.com/contest/1154/problem/ 题目意思:就是给你四个数,这四个数是a+b,a+c,b+c,a+b+c,次序未知要反求出a,b,c,d ...

  9. Codeforces Round #198 (Div. 2)A,B题解

    Codeforces Round #198 (Div. 2) 昨天看到奋斗群的群赛,好奇的去做了一下, 大概花了3个小时Ak,我大概可以退役了吧 那下面来稍微总结一下 A. The Wall Iahu ...

随机推荐

  1. Solon 1.5.29 发布,轻量级 Java 基础开发框架

    本次版本主要变化: 增加 captcha-solon-plugin 插件(提供滑块验证与选文字验证能力) 插件 sa-token-solon-plugin,升级 sa-token 为 1.26.0 插 ...

  2. 《微服务架构设计模式》读书笔记 | 第8章 外部API模式

    目录 前言 1. 外部API的设计难题 1.1 FTGO应用程序的服务及客户端 1.2 FTGO移动客户端API的设计难题 1.3 其他类型客户端API的设计难题与特点 2. API Gateway模 ...

  3. Jmeter系列(10)- Linux环境安装之Jmeter下载配置

    step-1下载 我是之前windows有,就直接copy到Linux系统了 step-2Jmter放到local目录 mv apache-jmeter-5.2.1 /usr/local/ step- ...

  4. ❤️【Android精进之路-03】创建第一个Android应用程序竟然如此简单❤️

    您好,我是码农飞哥,感谢您阅读本文,欢迎一键三连哦. 本文会重点介绍如何创建第一个Android应用,以及如何使用Android Studio进行调试 干货满满,建议收藏,需要用到时常看看.小伙伴们如 ...

  5. django class类即视图类添加装饰器的几种方法

    根据别人发布整理,个人爱好收集(原文:https://blog.csdn.net/mydistance/article/details/83958655 ) 第一种:定义函数装饰器,在函数,类中使用函 ...

  6. whistle安装

    可参考官方帮助文档:https://wproxy.org/whistle/install.html 系统:windows10   jdk:1.8.0_171    node:10.16.0    np ...

  7. cordova 打包 守护进程无法启动

    方案 1 : 添加环境变量 _JAVA_OPTIONS = -Xmx512M 2: 在新建的 系统变量里 变量名   _JAVA_OPTIONS 变量值   -Djava.net.preferIPv4 ...

  8. 『Python』matplotlib初识

    1. 核心原理 使用matplotlib绘图的原理,主要就是理解figure(画布).axes(坐标系).axis(坐标轴)三者之间的关系. 下面这幅图更详细: 以"美院学生张三写生画画&q ...

  9. python二级 第9套

    1. prInt.默认输出空格 2. 我的这种想法也行不通啊 format() 一次只能有一个未知量 2. 分割的结果就是列表 3. 对比"大学"    上一套的split('&q ...

  10. 淘宝商品html--网页结构

    淘宝商品html--网页结构 本篇爬虫紧接上一篇关于 泸州老窖 的爬虫随笔: import re import json def get_space_end(level): return ' ' * ...