Poj 1061 青蛙的约会(扩展欧几里得解线性同余式)
一、Description
我们把这两只青蛙分别叫做青蛙A和青蛙B,并且规定纬度线上东经0度处为原点,由东往西为正方向,单位长度1米,这样我们就得到了一条首尾相接的数轴。设青蛙A的出发点坐标是x,青蛙B的出发点坐标是y。青蛙A一次能跳m米,青蛙B一次能跳n米,两只青蛙跳一次所花费的时间相同。纬度线总长L米。现在要你求出它们跳了几次以后才会碰面。
Input
Output
二、题目分析
这道题用到了扩展欧几里得算法解线性同余问题,小弟数论没怎么学。今天看到一篇精辟的题解,于是略作修改,引用之。原文请看http://blog.csdn.net/swordholy/article/details/4423543
根据题意可知,题目要求的是求(X + K * M)mod L=(Y + K * N)mod L这个模方程的k的最小整数解;跟据模的性质对这个方程变形得:K * ( M - N ) + T * L=Y--X( T为引进的一整数);
令A= (M - N) ; B = Y - X; 得:K * A + T * L =B ( 0)
看到这个式子是不是感觉很眼熟,对,它就是扩展欧几里得法能解的标准方程A * X + B * Y= D 的标准形;唯一的不同是扩展欧几里得D 是前面两系数A,B的最大公约数;而(0)式中的B就不能保证了。
1、不过没关系,先用扩展欧几里得得出K * A + T *L=gac(A,L) 的一个解k0,t0;再观察两个式子:
K * A + T * L =B ( 0)
K0 * A + T0 * L=D (1) (令D = gcd(A,L))
将(0)式两边都除以D,得:
K * (A / D)+ T * (L /D)=B/D
因为D为A,B的最大公约数,所以A / D,L / D为整数,所以B / D必定为整数,否则方程无解;
将(1)式两边都乘以B / D 与( 0 )式比较:
K * A + T * L =B ( 0)
K0 *( B / D) * A + T0 *( B / D)* L=B (1)
得K = K0 * B / D; T = T0 * B / D;
2、接下来就是由一个解扩展成一个解系:
( 1)除以D得: K0 * (A / D ) + T0 * ( L / D)=1
因为(A / D )和( L / D)互质,将方程写成:
(K0 + U * ( L / D)) * (A / D ) + ( T0 + V * (A / D ) ) * ( L / D)=1;
只要U * ( L / D) * (A / D ) + V * (A / D ) ) * ( L / D)=0成立就行;
所以K ,T 的解系可以写成 k = (K0 + U * ( L / D)) * (B / D ) ,T=( T0 + V * (A / D ) ) * ( B / D)
接下来就是求k的最小整数解了;
因为K = (K0 mod (L / D) + (U + K0 / ( L / D) ) * ( L / D)) * (B / D);
所以Kmin=(K0 * (B / D)) mod (L / D);
3、 大功基本高成了,还差最后一步,那就是如何用扩展欧几里得解K * A + T * L=gac(A,L)
对A * X + T * L = D;
递归调用时令A = B ; B = A % B;(辗转相除法,求最大公约数)
将其变为形式(2) B * X + A % B * Y = D;
变形:B * X + A * Y - (A / B) * B * Y = D;
再变:A * Y+ B ( X - A / B * Y)=D; (3)
与(2)式B * X + A % B * Y = D;比较:
得:
当A = B ; B = A % B时:X = Y ; Y = X - A / B * Y;调用过程中的X , Y 就是对应的A , B 的解;当回到顶层时,A , B 就 是最初的A ,B,所以此时的X,Y就是所求解。
三、Java代码
import java.util.Scanner;
public class Main {
static long x0, y0;
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
long x = scan.nextInt();
long y = scan.nextInt();
long m = scan.nextInt();
long n = scan.nextInt();
long L = scan.nextInt();
if (x > y) {
long t = y;
y = x;
x = t;
t = n;
n = m;
m = t;
}
long a = Math.abs(m - n);
long b = L;
long c;
if (m > n) {
c = y - x;
} else {
c = x - y + L;
}
long d = gcd(a , b);
if(c%d!=0){
System.out.println("Impossible");
}else{
long add1 = x0*c/d ;
long add2 = Math.abs(b/d);
while( add1 <0 ){
add1 += add2;
}
while(add1 - add2 >= 0){
add1 -= add2;
}
System.out.println(add1);
}
}
public static long gcd(long a, long b) {
long t, d;
if (b == 0) {
x0 = 1;
y0 = 0;
return a;
}
d = gcd(b, a % b);
t = x0;
x0 = y0;
y0 = t - a / b * y0;
return d;
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
Poj 1061 青蛙的约会(扩展欧几里得解线性同余式)的更多相关文章
- poj 1061 青蛙的约会 (扩展欧几里得模板)
青蛙的约会 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit Status ...
- POJ - 1061 青蛙的约会 扩展欧几里得 + (贝祖公式)最小正整数解
题意: 青蛙 A 和 青蛙 B ,在同一纬度按照相同方向跳跃相同步数,A的起点为X ,每一步距离为m,B的起点为Y,每一步距离为 n,一圈的长度为L,求最小跳跃步数. 思路: 一开始按照追击问题来写, ...
- POJ 1061 青蛙的约会 扩展欧几里得
扩展欧几里得模板套一下就A了,不过要注意刚好整除的时候,代码中有注释 #include <iostream> #include <cstdio> #include <cs ...
- poj 1061 青蛙的约会 拓展欧几里得模板
// poj 1061 青蛙的约会 拓展欧几里得模板 // 注意进行exgcd时,保证a,b是正数,最后的答案如果是负数,要加上一个膜 #include <cstdio> #include ...
- POJ.1061 青蛙的约会 (拓展欧几里得)
POJ.1061 青蛙的约会 (拓展欧几里得) 题意分析 我们设两只小青蛙每只都跳了X次,由于他们相遇,可以得出他们同余,则有: 代码总览 #include <iostream> #inc ...
- poj 1061 青蛙的约会+拓展欧几里得+题解
青蛙的约会+拓展欧几里得+题解 纵有疾风起 题意 两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面.它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止.可是它们出 ...
- pku 1061 青蛙的约会 扩展欧几里得
青蛙的约会Time Limit: 1000MS Memory Limit: 10000KTotal Submissions: 120482 Accepted: 25449Description 两只青 ...
- POJ 1061 青蛙的约会(欧几里得扩展)
题意:已知青蛙1位置x,速度m,青蛙2位置y,速度n,纬线长度为l,求他们相遇时最少跳跃次数. 思路:设最小跳跃次数为k,则(x + k*m) - (y + k*n) = q*l:经过整理得到k*(n ...
- [poj1061]青蛙的约会<扩展欧几里得>
题目链接:http://poj.org/problem?id=1061 其实欧几里得我一直都知道,只是扩展欧几里得有点蒙,所以写了一道扩展欧几里得裸题. 欧几里得算法就是辗转相除法,求两个数的最大公约 ...
随机推荐
- [JavaScript]WebBrowser控件下IE版本的检测
转载请注明原文地址:https://www.cnblogs.com/litou/p/10772272.htm 在客户端检查用户使用的浏览器类型和版本,都是根据navigator.userAgent属性 ...
- lua解析json
自己写的lua解析json,带容错,如果要是用于格式检查,得修改下.很简单直接贴代码 --------------------------------------------------json解析- ...
- 我的Android进阶之旅------>MIME类型大全
今天在实现一个安装apk的代码中看到一段代码为:application/vnd.android.package-archive,不知其意,所以百度了一下,了解到这是一种MIME的类型,代表apk类型. ...
- 跟我一起用Symfony写一个博客网站;
我的微信公众号感兴趣的话可以扫一下, 或者加微信号 whenDreams 第一部分:基础设置,跑起一个页面-首页 第一步: composer create-project symfony/fram ...
- 常见数据挖掘算法的Map-Reduce策略(2)
接着上一篇文章常见算法的mapreduce案例(1)继续挖坑,本文涉及到算法的基本原理,文中会大概讲讲,但具体有关公式的推导还请大家去查阅相关的文献文章.下面涉及到的数据挖掘算法会有:L ...
- Django下MEDIA_ROOT, MEDIA_URL, STATIC_ROOT, STATIC_URL解惑
Django中settings中的四个设置参数的一些故事: MEDIA_ROOT, MEDIA_URL, STATIC_ROOT, STATIC_URL 1.MEDIA_ROOT与MEDIA_URL ...
- ERROR 2003 (HY000): Can't connect to MySQL server on 'ip地址' (110)
用windows能远程连接数据库服务器,用ubuntu就报错,怎么都连不上,报这个错ERROR 2003 (HY000): Can't connect to MySQL server on 'ip地址 ...
- CAS的实现Atomic类库
atomic 原子(atomic)本意是"不能被进一步分割的最小粒子",而原子操作(atomic operation)意为"不可被中断的一个或一系列操作".在多 ...
- POJ - 3414 Pots 【BFS】
题目链接 http://poj.org/problem?id=3414 题意 给出两个杯子 容量分别为 A B 然后给出C 是目标容量 有三种操作 1 将一个杯子装满 2.将一个杯子全都倒掉 3.将一 ...
- SPFA 算法(剪辑)(学习!)
SPFA算法 单源最短路径的算法最常用的是Dijkstra,些算法从时间复杂度来说为O(n^2),但是面对含有负权植的图来说就无能为力了,此时 Dellman-ford算法就有用了,这咱算法是采用的是 ...