牛客Wannafly A:https://www.nowcoder.com/acm/contest/160/A
有一个计数器,计数器的初始值为0,每次操作你可以把计数器的值加上a1,a2,...,an中的任意一个整数,操作次数不限(可以为0次),问计数器的值对m取模后有几种可能。(每个数无限取)
翡蜀定理:对于任何整数a,b,d=gcd(a,b),关于未知数x和y的线性丢番图方程(翡蜀等式):ax+by=m。
当m为d的倍数时有整数解。对于ax+by=1,当a,b互质的时候有解。
假设对数an取的个数为kn,可得到如下等式:
a1*k1+a2*k2+a3*k3+......an*kn=p
当p为gcd(a1,a2,a3...an)的倍数时,等式有解。
所以我们只要求出d=gcd(a1,a2,a3...an),然后求出小于m且是d的倍数的个数即可。
注意:这里求公约数的是时候要把m也算进去。
p=gcd(a1,a2...an) 设px%m=a,p的x倍对m取余为a
则有 px-my=a,翡蜀定理,若想要等式有解a必须为gcd(p,m)的倍数.
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
ll gcd(ll a,ll b)
{
if(b==0) return a;
return gcd(b,a%b);
}
int main()
{
ll n,m;
cin>>n>>m;
ll ans=m;
for(int i=0;i<n;i++)
{
int temp;
cin>>temp;
ans=gcd(temp,ans);
}
cout<<ll(m/ans)<<endl;
return 0;
}