#交互#CF1375F Integer Game
2021/8/10 23:38:20
本文主要是介绍#交互#CF1375F Integer Game,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目
有三堆石子初始石子数分别为\(a,b,c\),可以选择先手还是后手操作,
每次操作形如先手选择一个正整数 \(k\) ,后手自由选择一堆石子加上 \(k\) ,
但是不能和上一次操作选择的石堆相同。
如果在1000次操作内,存在两堆石子相同则先手必胜,否则先手必败
分析
考虑如果单纯补上两堆石子的差值那么后手必然会选择第三堆石子或者大的那堆石子,
那么就是要让后手无法选择,所以要让\(b-a=c-b\)并且强制\(c\)这一堆不能选先手必胜,
考虑先设置公差,\(c\)要倒数第二轮,那么可以先指定\(b\)是哪一堆,一开始设置\(inf\)即可,
那么\(b\)就是第二大的,因为最后要使\(b*2=a+c\),那么可以将公差设为\(b*2-a-c\),
这样后手选的数一定是最大的,这样再设置公差三轮先手必胜
代码
#include <cstdio> #define rr register using namespace std; typedef long long lll; lll a[3]; inline signed Get_Rank(lll x){ printf("%lld\n",x),fflush(stdout); rr int ret; scanf("%d",&ret); if (!ret) return -1; a[--ret]+=x; return ret; } signed main(){ for (rr int i=0;i<3;++i) scanf("%lld",&a[i]); printf("First\n"),fflush(stdout); rr int now0=Get_Rank(1e10); if (now0==-1) return 0; rr int now1=Get_Rank(a[now0]*3-a[0]-a[1]-a[2]); if (now1==-1) return 0; Get_Rank(a[now1]-a[now0]); return 0; }
这篇关于#交互#CF1375F Integer Game的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-07-02微服务启动nacos注册上去了,但是一直没有收到请求-icode9专业技术文章分享
- 2024-07-02如何检查文件的编码格式-icode9专业技术文章分享
- 2024-07-02sublime 更改编码格式-icode9专业技术文章分享
- 2024-06-30uniAPP 实现全屏左右滚动滚动的效果-icode9专业技术文章分享
- 2024-06-30如何在本地使用授权或插件-icode9专业技术文章分享
- 2024-06-30伪静态规则配置方法汇总-icode9专业技术文章分享
- 2024-06-29易优CMS安装常见问题汇总-icode9专业技术文章分享
- 2024-06-28易优新手必读安装教程-icode9专业技术文章分享
- 2024-06-28忘记eyoucms后台密码怎么办?-icode9专业技术文章分享
- 2024-06-26终极指南:Scrum中如何设置需求优先级