科大讯飞竞赛 A、张老师和菜哭武的游戏

科大讯飞竞赛 A、张老师和菜哭武的游戏
链接:https://ac.nowcoder.com/acm/contest/5477/A
来源:牛客网

题目描述
天才程序员菜哭武和张老师有一天到一个城市旅游,旅途中菜哭武觉得无聊就想和张老师玩一个游戏。菜哭武有n个石子,每个石子都标有1到n之间到数,且各不相同,一开始他们会随机从这堆石子选一个石子放置到一个集合中,张老师选的数是a,菜哭武选的是b(a和b不相同)。接下来菜哭武和张老师轮流按照如下规则拿走一个石子:当石子x能被拿走时,当且仅当集合存在y和z,满足x等于y+z或者y-z,当x被拿走时,把它放到集合中。谁完成最后一轮操作时,谁获胜。张老师总是先手,于是张老师就好奇当决定好a和b时,他是否总是能获胜,你能帮助一下张老师吗?

输入描述:
第一行一个整数T(1≤T≤500),表示共有T组测试数据。
对于每组测试数据,第一行三个整数n(2≤n≤20000)、a和b(1≤a,b≤n, a≠b)。

输出描述:
若张老师能获胜输出Yes,反之No。
题目解析:
【1】。前导知识:拓展欧里几得
我们知道对于ax + by = cax+by=c 存在整数解x与y,需要gcd(a,b)是c的因子。
对于用a和b求解出来的数随意组合也符合上面的ax + by = cax+by=c
那么这题,给出了a,b,直接求解gcd即可,用n除掉gcd就是可以拿走的数。在对这个数判断奇偶即可
【2】解析:刚开始,集合里有a,b。然后张拿了一个数p,满足a+b/a-b,放入集合。不断进行的话,集合里就会存在各种的ax+by了。所以如果p可以被拿走,是要满足:ax+by=p的。那么p就是gcd(a,b)的倍数(因为x,y可能是负数)。n/gcd(a,b)可以求出1-n中有几个数是gcd(a,b)的倍数,如果有奇数个,根据游戏顺序,张老师胜,否则输。
疑问: 为什么1~n所有的g(a,b)的倍数数最终都可以通过集合内的数加减得到?????
题解:
#include<bits/stdc++.h>
#include

using namespace std;
int main()
{
int t;
cin>>t;
while(t–)
{
int n, a, b;
cin>>n>>a>>b;
if(n/(__gcd(a,b))%2==1)
cout<<“Yes”<<endl;
else
cout<<“No”<<endl;
}
return 0;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值