先上干货:

定理1:

如果d = gcd(a,b),则必能找到正的或负的整数k和l,使ax + by = d.

(参考exgcd:http://www.cnblogs.com/dilthey/p/6804137.html

定理2:

一元线性同余方程ax ≡ n (mod b) 有解,当且仅当gcd(a,b)|n.

也就是说,解出了ax+by=gcd(a,b),就相当于解出了ax≡n(mod b) (而且只要满足gcd(a,b)|n,就一定有解)

定理3:

若gcd(a,b) = 1,则方程ax ≡ n (mod b)在[0, b-1]上有唯一解.

由上可知ax ≡ n (mod b) 即方程 ax + by = n,由定理1可知必然存在x,y满足 ax + by = gcd(a,b) = 1,则必然存在nx,ny满足 ax + by = n

则必然ax ≡ n (mod b)有解nx,由于nx+kb都是该方程的解,则在[0, b-1]上必然出现一个解。

再证唯一性:

唯一满足mod b = 0的条件的,只有x1 = x2

定理4:

若gcd(a, b) = d,则方程ax ≡ n (mod b)在[0, b/d - 1]上有唯一解.

这样,如果我有一个方程ax ≡ n (mod b)的任意解X,那么我先X mod (b/d),使得其在范围[-b/d+1,b/d-1]范围内,

再加上b/d就使其在范围[1,2(b/d)-1]范围内,再mod (b/d)就可以使其处在[0,b/d -1]范围内了。

即在[0,b/d-1]范围内的解x=[ X mod (b/d) + (b/d) ] mod (b/d).

分割线

然后正式关于题目:

题目链接:http://poj.org/problem?id=1061

题解:

青蛙A:a = ( x + mt ) mod L

青蛙B:b = ( y + nt ) mod L

现在要使得a=b,即( x + mt ) = ( y + nt ) (mod L),即( x - y ) + ( m - n ) t = kL;

即求最小的正整数t满足 ( m - n ) t + KL = y - x (K=-k),即求一元线性同余方程( m - n ) x ≡ ( y - x ) (mod L) 的解;

那么就像上面那样,先算( m - n ) * x + L * K = gcd( m - n , L ),得到一个x的值;

然后判断( y - x ) mod gcd( m - n , L ) == 0 ?,若能整除,则有解;

然后就只要先把x *= ( y - x ) / gcd( m - n , L ) ,再根据上面求出解集中的最小正整数即为答案;

PS.当然,最后一步求[0,b/d-1]范围内的唯一解时,由于要mod (b/d),我们要保证b/d为正,在本题中,即保证L/d为正,故d要为正。

AC代码:

  1. #include<cstdio>
  2. #include<algorithm>
  3. typedef long long ll;
  4. using namespace std;
  5. ll x,y,m,n,L;
  6. ll d,ans,K;
  7. void exgcd(ll a,ll b,ll &d,ll &x,ll &y){
  8. if(!b){d=a;x=;y=;}
  9. else {exgcd(b,a%b,d,y,x);y-=(a/b)*x;}
  10. }
  11. int main()
  12. {
  13. scanf("%lld%lld%lld%lld%lld",&x,&y,&m,&n,&L);
  14. if(m<n)
  15. {
  16. swap(m,n);
  17. swap(x,y);
  18. }
  19. exgcd(m-n,L,d,ans,K);
  20. if(d== || (x-y)%d!=) printf("Impossible\n");
  21. else
  22. {
  23. ans*=(y-x)/d;
  24. ans=(ans%(L/d)+(L/d))%(L/d);
  25. printf("%I64d\n",ans);
  26. }
  27. }

PS.曾经刚开始搞ACM的时候,就因为这题是POJ第一页上为数不多的中文题而钻了很久,不过以当时的实力,想想就知道怎么磕都磕不出来的,今天总算把这道题给补上了,感觉还是不错的

POJ 1061 - 青蛙的约会 - [exgcd求解一元线性同余方程]的更多相关文章

  1. POJ 1061青蛙的约会。求解(x+mT)%L=(y+nT)%L的最小步数T。

    因为是同余,所以就是(x+mT)%L-(y+nT)%L=0.可以写成(x-y+(m-n)T)%L=0.就是这个数是L的倍数啦.那么我可以这样x-y+(m-n)T + Ls = 0.就可以了,s可正可负 ...

  2. NEFU 84 - 五指山 - [exgcd求解一元线性同余方程]

    题目链接:http://acm.nefu.edu.cn/JudgeOnline/problemShow.php?problem_id=84 Time Limit:1000ms Memory Limit ...

  3. poj 1061 青蛙的约会 拓展欧几里得模板

    // poj 1061 青蛙的约会 拓展欧几里得模板 // 注意进行exgcd时,保证a,b是正数,最后的答案如果是负数,要加上一个膜 #include <cstdio> #include ...

  4. ACM: POJ 1061 青蛙的约会 -数论专题-扩展欧几里德

    POJ 1061 青蛙的约会 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%lld & %llu  Descr ...

  5. POJ.1061 青蛙的约会 (拓展欧几里得)

    POJ.1061 青蛙的约会 (拓展欧几里得) 题意分析 我们设两只小青蛙每只都跳了X次,由于他们相遇,可以得出他们同余,则有: 代码总览 #include <iostream> #inc ...

  6. POJ 1061 青蛙的约会(exgcd)

    嗯... 题目链接:http://poj.org/problem?id=1061 两只青蛙相遇时肯定满足:x+k*m≡y+k*n(mod L) x+k*m-(y+k*n)=L*s k*(n-m)-s* ...

  7. poj 1061 青蛙的约会 (扩展欧几里得模板)

    青蛙的约会 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit Status ...

  8. poj 1061青蛙的约会

    青蛙的约会 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 90083   Accepted: 16257 Descripti ...

  9. POJ 1061 青蛙的约会 题解

    青蛙的约会 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 139755   Accepted: 31803 Descript ...

随机推荐

  1. 用python开发android应用 【转载】

    用python开发android应用 [转载] 转载自:http://www.miui.com/thread-995114-1-1.html Python是动态语言,比较简洁.Android不直接支持 ...

  2. SpringMVC -- 梗概--源码--贰--异常管理

    附:实体类 Class : User package com.c61.entity; import java.text.SimpleDateFormat; import java.util.Date; ...

  3. Jackson Gson Json.simple part 2

    这篇blog介绍 Jackson 的特点和使用方法 Jackson支持三种使用方法 流API(streaming api Incremental parsing/generation) JsonPar ...

  4. Git Step by Step – (8) Git的merge和rebase

    前面一篇文章中提到了"git pull"等价于"git fetch"加上"git merge",然后还提到了pull命令支持rebase模式 ...

  5. 浅谈iPhone OS(iOS)架构

    iPhone OS(现在叫iOS)是iPhone, iPod touch 和 iPad 设备的操作系统

  6. jquery easyui datagrid 无滚动条,datagrid 没垂直滚动条

    jquery easyui datagrid 无滚动条,datagrid 没垂直滚动条 ============================== 蕃薯耀 2018年2月6日 http://www. ...

  7. 【RF库XML测试】parse xml

    Name:Parse XmlSource:XML <test library>Arguments:[ source | keep_clark_notation=False ]Parses ...

  8. Hadoop集群三种作业调度算法介绍

    Hadoop集群中有三种作业调度算法,分别为FIFO,公平调度算法和计算能力调度算法 先来先服务(FIFO) Hadoop中默认的调度器FIFO,它先按照作业的优先级高低,再按照到达时间的先后选择被执 ...

  9. cookie设置在特定时间点过期的方法

    假设需求为:在当天晚上0:00过期. 方法: 得到当天晚上0:00这个时间点的一个时间. function getNextDate(){        var d = new Date(),      ...

  10. 异构GoldenGate 12c 单向复制配置

    1.分别在windows2008.linux平台部署oracle 11.2.0.4 2.分别在windows2008.linux平台部署gg. 2.1 windows平台: gg的安装目录位 C:\o ...