首页 > 其他 > 详细

poj2115-C Looooops -线性同余方程

时间:2016-01-30 02:11:40      阅读:191      评论:0      收藏:0      [点我收藏+]

线性同余方程的模板题。和青蛙的约会一样。

 

#include <cstdio>
#include <cstring>

#define LL long long

using namespace std;
//A+n*C = B mod 2^k
//n*C = B-A mod 2^k


LL A,B,C,MOD;
int k;

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

int main()
{
    while(scanf("%I64d%I64d%I64d%d",&A,&B,&C,&k) && (A||B||C||k))
    {
        LL x,y;
        LL a=C,b=B-A;
        MOD = 1LL<<k;
        LL d = ExGCD(a,MOD,x,y);
        if(b%d )
        {
            printf("FOREVER\n");
        }
        else
        {
            x=(x*(b/d))%MOD;
            x=(x%(MOD/d)+MOD/d)%(MOD/d);
            printf("%I64d\n",x);
        }
    }
}

 

poj2115-C Looooops -线性同余方程

原文:http://www.cnblogs.com/helica/p/5170258.html

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