首页 > 其他 > 详细

【codevs1200】 NOIP2012—同余方程

时间:2016-09-27 20:03:11      阅读:129      评论:0      收藏:0      [点我收藏+]

codevs.cn/problem/1200/ (题目链接)

题意:求关于 x 的同余方程 ax ≡ 1 (mod b)的最小正整数解。

Solution 
   
  这道题其实就是求a mod b的逆元x。所谓逆元其实很简单,记a的关于模p的逆 
元为a^-1,则a^-1满足aa^-1≡ 1(mod p),用扩展欧几里德即可。 
  关于扩展欧几里德,有博客写了证明:blog.csdn.net/lincifer/article/details/49391175 
   
代码:

// codevs1200
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define inf 2147483640
#define Pi 3.1415926535898
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std;



void exgcd(LL a,LL b,LL &x,LL &y) {
    if (b==0) {x=1;y=0;return;}
    exgcd(b,a%b,x,y);
    LL t=x;x=y;y=t-a/b*y;
}
int main() {
    LL x,y,a,b;
    scanf("%lld%lld",&a,&b);
    exgcd(a,b,x,y);
    printf("%lld",(x+b)%b);
    return 0;
}

  

【codevs1200】 NOIP2012—同余方程

原文:http://www.cnblogs.com/MashiroSky/p/5914057.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!