模数的世界(同余性质+exgcd)

博客围绕ACM竞赛题目https://ac.nowcoder.com/acm/contest/9983/A展开,先特判0,0,0,接着利用贪心思路确定为(p - 1),将问题转化为构造互质的q1、q2满足特定条件,把k1、k2写成表达式,通过构造使k2 = p - b,用exgcd求特解并构造通解。

https://ac.nowcoder.com/acm/contest/9983/A



思路:

首先特判0,0,0;

其次第一点: x%p==a <--->必存在(p-1)*k1%p==a.所以贪心上是(p-1)

那问题就变成了构造q1,q2互质且他们 (p-1)*q1%p==a&&(p-1)*p2%p==b

然后将k1,k2给转化成式子。

(p-1)*k1%p==a;

(p-1)*k2%p==b;

再将k1,k2写出表达式

k1=t1p-a

k2=t2p-b

题目要使k1,k2互质,不妨构造一个,使k2=p-b;那么(t1-p)%k2==1 <--->t1p+mk2=1+a.    这个p,k2是已知的,t1,m就是系数,就等价ax+by=c;已知a,b,用exgcd求一个特解。

再构造通解

统统回代回去。

#include<iostream>
#include<vector>
#include<queue>
#include<cstring>
#include<cmath>
#include<map>
#include<set>
#include<cstdio>
#include<algorithm>
#define debug(a) cout<<#a<<"="<<a<<endl;
using namespace std;
const int maxn=1e5;
typedef long long LL;
inline LL read(){LL x=0,f=1;char ch=getchar();	while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}while (isdigit(ch)){x=x*10+ch-48;ch=getchar();}
return x*f;}
LL exgcd(LL &x,LL &y,LL a,LL b)
{
    if(!b)
    {
        x=1;
        y=0;
        return a;
    }
    LL ret=exgcd(y,x,b,a%b);
    y-=a/b*x;
    return ret;
}
int main(void)
{
  cin.tie(0);std::ios::sync_with_stdio(false);
  LL t;cin>>t;
  while(t--){
    LL a,b,p;cin>>a>>b>>p;
    LL k1=p-a,k2=p-b,x,y;
    if(!a&&!b) cout<<0<<" "<<0<<" "<<0<<"\n";
    else{
        exgcd(x,y,p,k2);
        x=(x%k2+k2)%k2;
        if(!x) x+=k2;
        x*=(1+a);
        k1=x*p-a;
        cout<<(p-1)<<" "<<k1*(p-1)<<" "<<k2*(p-1)<<"\n";
    }
  }
return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值