CF1370C题解
本蒟蒻的第二篇题解,找题归功于教练
这道题目找好了规律很简单:
具体思路:
题目大意:
有一个正整数 nnn。两名玩家轮流操作。每次操作可以执行以下一种:
- 将 nnn 除以一个 nnn 的奇数因子。
- 将 nnn 减去 111。
问先手是否有必胜策略。如果先手有必胜策略,输出 Ashishgup,否则输出 FastestFinger。
题目分析:
首先,拿到 111 的会输掉。
直观分析可以得到:
- 当 AAA 拿到 222 或奇数的时候必赢,因为 2−12-12−1 或奇数 ÷\div÷ 奇数都使得对方得到 111。
在此基础上继续分析其他数值:设 pip_ipi 为奇质数:
如果一个数是 2×p2\times p2×p,那么 AAA 只能执行 ÷\div÷ 奇数操作,对方拿到 222,对方必赢,因此 AAA 必输。
如果一个数是 2×p1×p2×...2\times p_1\times p_2\times...2×p1×p2×... 那么 AAA 可以执行 ÷\div÷ 奇数操作,是的对方拿到 2×p2\times p2×p,因此 AAA 必赢。
当 AAA 为 2k,k>12^k,k>12k,k>1 时候, AAA 只能执行 −1-1−1 操作,因此 AAA 必输。
如果一个数是是 2k×p1×p2...2^k\times p_1\times p_2...2k×p1×p2...,AAA 执行 ÷\div÷ 奇数操作,对方得到 2k2^k2k,对方必输,因此 AAA 必赢。

知道以上信息代码就很简单了。
源码:
//A 必胜态 2,3,奇数... 2*ji^2,2^k*ji
//A 必输 1,4,8...2^k(k>1);2*ji
#include <bits/stdc++.h>
using namespace std;
bool prime(int x) {
for(int i=2;i*i<=x;i++) {
if(x%i==0){
return false;
}
}
return true;
}
bool work() {
int x;
cin>>x;
if(x==1)return 0;//0必输态
else if(x==2||x&1) return 1;//2和奇数必赢态
else if(x&2) {//2*奇数
x>>=1;
if(prime(x))return 0;//2*奇质数:必输态
else return 1;//2*奇数*奇数 必赢态
}
else {
while(!(x&1))x>>=1;
if(x==1) return 0;//2^k,必输态
else return 1;//2^k*ji必赢态。
}
}
int main() {
int t;
cin>>t;
while(t--){
if(work())cout<<"Ashishgup\n";
else cout<<"FastestFinger\n";
}
return 0;
}
CF1370C题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- 从购物找零到两数之和:一道经典算法题的深度解析|LeetCode 1 两数之和
LeetCode 1 两数之和(Two Sum) 点此看全部题解 LeetCode必刷100题:一份来自面试官的算法地图(题解持续更新中) 生活中的算法 还记得上次去超市购物吗?你拿着一张100元钞票 ...
- 新格局,新生态!天翼云以国云智算底座赋能AI产业发展!
近日,中国云产业联盟暨中关村云计算产业联盟(以下简称"云联盟")主办的"首届AIGC全网小程序应用创新大会暨云联盟・移动应用专业委员会成立发布会"在中关村国家自 ...
- Git 忽略文件配置全解析
Git 忽略文件配置全解析 在Git版本控制系统中,.gitignore文件扮演着至关重要的角色.它允许我们指定哪些文件或目录应该被Git忽略,即不被纳入版本控制之中.这对于避免提交敏感信息.构建产物 ...
- Q:群晖磁盘断电导致,无法访问系统分区
1.群晖磁盘断电导致,无法访问系统分区 2.点击存储空间管理员-总览-点击修复 3.存储空间-文件系统检查-重启 4.重启后正常
- 什么是Kappa架构?
一.简介 相当于在Lambda架构上去掉了批处理层(Batch Layer),只留下单独的流处理层(Speed Layer).通过消息队列的数据保留功能,来实现上游重放(回溯)能力. 当流任务发生代码 ...
- IDEA中使用Yapi上传接口
一.Idea下载插件YapiUpload 二.修改该项目的隐藏文件夹idea .idea文件下修改misc.xml增加如下配置 <component name="yapi" ...
- Luogu P3041 USACO12JAN Video Game G 题解 [ 紫 ] [ AC 自动机 ] [ 动态规划 ]
Video Games G:弱智紫题,30min 切了,dp 思路非常板. 多模式串一看肯定就是要建出 AC 自动机,然后在 fail 树里下传标记,预处理每个节点到达后的得分. 然后设计 \(dp_ ...
- [BZOJ3600] 没有人的算术 题解
妙不可言!妙绝人寰! 单点修,区间查,包是线段树的.考虑如何比较两节点大小. 考虑二叉搜索树,我们只要再给每个节点附一个权值,就可以比较了! 注意力相当惊人的注意到,假如给每个点一个区间 \([l_x ...
- Nginx - [01] 概述
客户端访问增加.并发量增大. 001 || 什么是Nginx Nginx是一个高性能的HTTP和反向代理Web服务器,同时也提供了IMAP/POP3/SMTP服务. 占有内存少,并发能力强. 002 ...
- 2024.11.12随笔&联考总结
前言 心情不好,因为考试时 T2T3 全看错题了,导致 T2 没做出来,T3 一份没得.然后下午打球眼镜架子坏了,回机房才发现被高二的盒了. 但还是稍微写一下总结吧. 总结 感觉我今天做题状态还行,思 ...