扩展中国剩余定理模板(EXCRT)

本文介绍了一种使用结构体Node和ExCrt实现的异或欧几里得算法,用于计算模逆并解决模运算中的查询问题。通过递归求解最大公约数,然后应用扩展欧几里得算法找到模逆元素。核心函数`Query()`实现了根据给定条件更新并返回最终结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

struct Node {
    LL m, b;
};
struct ExCrt {
    int n;
    Node a[Maxk + 5];

    LL exgcd (LL x, LL y, LL &a, LL &b) {
        if (y == 0) {
            a = 1, b = 0;
            return x;
        }
        LL tmp = exgcd (y, x % y, b, a);
        b -= (x / y) * a;
        return tmp;
    }
    LL Query () {
        LL m = a[1].m, b = a[1].b;
        rep (i, 2, n) {
            //x = b[1] (mod m[1])
            //x = b[2] (mod m[2])
            //b[1] + m[1] * f = b[2] + m[2] * g
            //M = lcm (m[1], m[2])
            //x = b[1] + m[1] * f (mod M)
            //m[1] * f + m[2] * (-g) = b[2] - b[1]
            LL f, g, _gcd, M;
            _gcd = exgcd (m, a[i].m, f, g);
            M = m / _gcd * a[i].m;
            f *= (a[i].b - b) / _gcd;
            f = (f % a[i].m + a[i].m) % a[i].m;
            b = (b + m * f) % M;
            m = M;
        }
        return b;
    }
}F;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值