Wannafly挑战赛22---A 计算器

1 篇文章 0 订阅
1 篇文章 0 订阅

牛客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;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值