Codeforces Round 651 (Div. 2)C. Number Game 博弈 奇偶数 偶数的表示

Submission #244500083 - Codeforces

题目:

思路:

此题要从奇偶性上入手。(注意除的是奇因数,即一个奇数。我想成质数了)

1.当A选手开局是1时,A败。

2.当A选手开局是2奇数时,A必胜。(奇数除以自己就是1,给对手1)

3.当A选手开局是偶数 ,分情况讨论(此题难点

偶数可以写成 (2^x)*y (y不是2的倍数,都给前一项了,所以y是奇数)


当y是1时,这个偶数是2^x,没有奇因数,只能减一。

这样的话对手拿到奇数,如果是给2减的1,则A胜,否则由上文知,A败。


当y>1时,

因为减1直接败,我们给它除去这个y。

  1. //是质数,除掉,对手偶,2我们输,不是2我们赢
  2. //不是质数,赢:除完是2就别除完,不是2就除完

核心代码:

复制代码
int is_prime(int x)
{
	for(int i = 2; i * i <= x; i++)
	{
		if (x % i == 0)return 0;
	}
	return 1;
}
void solve()
{
	int n;
	cin >> n;
	if (n == 1)
	{
		cout << "FastestFinger" << endl;
	}
	else if (n == 2||n%2==1)
	{
		cout << "Ashishgup" << endl;
	}
	else
	{
		int tmp = n;
		while (tmp % 2 == 0)
		{
			tmp /= 2;
		}
		if (tmp == 1)//2^x
		{
			cout << "FastestFinger" << endl;
		}
		else
		{
			if (is_prime(tmp)&&n/tmp==2)
			{
				cout << "FastestFinger" << endl;
 
			}
			else
				cout << "Ashishgup" << endl;
		}
	}
}
signed main()
{
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	int t = 1;
	cin >> t;
	while (t--)
	{
		solve();
	}
	return 0;
}
相关推荐
L_090716 分钟前
【C++】高阶数据结构 -- 红黑树
数据结构·c++
A_nanda29 分钟前
c# MOdbus rto读写串口,如何不相互影响
算法·c#·多线程
代码雕刻家2 小时前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯
Ulyanov2 小时前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
智者知已应修善业4 小时前
【查找字符最大下标以*符号分割以**结束】2024-12-24
c语言·c++·经验分享·笔记·算法
91刘仁德4 小时前
c++类和对象(下)
c语言·jvm·c++·经验分享·笔记·算法
diediedei4 小时前
模板编译期类型检查
开发语言·c++·算法
阿杰学AI4 小时前
AI核心知识78——大语言模型之CLM(简洁且通俗易懂版)
人工智能·算法·ai·语言模型·rag·clm·语境化语言模型
mmz12075 小时前
分治算法(c++)
c++·算法
一切尽在,你来5 小时前
C++多线程教程-1.2.1 C++11/14/17 并发特性迭代
开发语言·c++