加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Acwing-204-表达整数的奇怪方式(扩展中国剩余定理)

发布时间:2020-12-16 09:14:15 所属栏目:百科 来源:网络整理
导读:链接: https://www.acwing.com/problem/content/206/ 题意: 给定2n个整数a1,a2,…,an和m1,m2,mn,求一个最小的非负整数x,满足?i∈[1,n],x≡mi(mod ai)。 思路: 扩展中国剩余定理模板题. 代码: #include bits/stdc++.husing namespace std;typedef long long

链接:

https://www.acwing.com/problem/content/206/

题意:

给定2n个整数a1,a2,…,an和m1,m2,mn,求一个最小的非负整数x,满足?i∈[1,n],x≡mi(mod ai)。

思路:

扩展中国剩余定理模板题.

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;

LL R[50],M[50];
int n;

LL ExGcd(LL a,LL b,LL &x,LL &y)
{
    if (b == 0)
    {
        x = 1,y = 0;
        return a;
    }
    LL d = ExGcd(b,a%b,x,y);
    LL tmp = y;
    y = x-(a/b)*y;
    x = tmp;
    return d;
}

LL ExCRT()
{
    LL m = M[1],r = R[1],y,gcd;
    for (int i = 2;i <= n;i++)
    {
        gcd = ExGcd(m,M[i],y);
        if ((r-R[i])%gcd != 0)
            return -1;
        x = (r-R[i])/gcd*x%M[i];
        r -= m*x;
        m = m/gcd*M[i];
        r %= m;
    }
    return (r%m+m)%m;
}

int main()
{
    scanf("%d",&n);
    for (int i = 1;i <= n;i++)
        scanf("%lld%lld",&M[i],&R[i]);
    printf("%lldn",ExCRT());

    return 0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读