题意:
有一个N个洞的山,兔子躲在洞内,狼以自己所在洞跳M个位,问狼能不能找到兔子.其实就是能不能遍历所有的点.
思路:
这题用欧几里德算法解,也就是说洞的数和跳跃的数最大公约数为1.
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int gcd(int m,int n)
{
return n==0?m:gcd(n,m%n);
}
int main()
{
int P;
cin>>P;
while(P--)
{
int m,n;
cin>>m>>n;
if(gcd(m,n)==1)
cout<<"NO"<<endl;
else
cout<<"YES"<<endl;
}
}
本文介绍了一个利用欧几里德算法解决遍历问题的方法,具体为判断一只狼能否通过跳跃遍历所有洞穴来找到躲藏的兔子。文章提供了完整的C++代码实现,并解释了最大公约数(GCD)在该问题中的应用。
806

被折叠的 条评论
为什么被折叠?



