exgcd模板

\(ax+by\)
\(=gcd(a,b)\)
\(=gcd(b,a%b)\)
\(=gcd(b,a-(a/b)*b)\)
\(=bx'+(a-(a/b)*b)y'\)
\(=ay'+(x'-(a/b)y')b\)

\(x=y'\)
\(y=x'(a/b)y\)


#include<cstdio>
#include<algorithm>
using namespace std;
pair<int,int> exgcd(int x,int y)
{
    if(x==1&&y==0)
    return make_pair(x,y);
    pair<int,int> ans=exgcd(y,x%y);
    return make_pair(ans.second,ans.first-(x/y)*ans.second);
} 
int main()
{
    int a,b;
    scanf("%d%d",&a,&b);
    pair<int,int> ans=exgcd(a,b);
    printf("%d\n",(ans.first%b+b)%b);
    return 0;
}
全部评论

相关推荐

萧索X:写篮球联赛干嘛,陪老板打篮球吗。还有实习经历要写自己所在岗位具体完成什么工作,自己的任务具体完成了什么需求,给公司带来了哪些量化增长
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务