[暑假集训--数论]poj1061 青蛙的约会
Description
我们把这两只青蛙分别叫做青蛙A和青蛙B,并且规定纬度线上东经0度处为原点,由东往西为正方向,单位长度1米,这样我们就得到了一条首尾相接的数轴。设青蛙A的出发点坐标是x,青蛙B的出发点坐标是y。青蛙A一次能跳m米,青蛙B一次能跳n米,两只青蛙跳一次所花费的时间相同。纬度线总长L米。现在要你求出它们跳了几次以后才会碰面。
Input
Output
Sample Input
1 2 3 4 5
Sample Output
4
距离是L-(y-x),每一次两位长者之间的距离缩短了(n-m)
然后exgcd
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<queue>
#include<deque>
#include<set>
#include<map>
#include<ctime>
#define LL long long
using namespace std;
inline LL read()
{
LL x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
inline LL exgcd(LL a,LL b,LL &x,LL &y)
{
if (!b){x=1ll;y=0ll;return a;}
LL gcd=exgcd(b,a%b,x,y);
LL t=x;x=y;y=t-a/b*y;
return gcd;
}
inline LL calc(LL a,LL b,LL c)//ax==b(mod c)
{
LL x,y;
LL tt=exgcd(a,c,x,y);
if (b%tt!=)return -;
x=(x*b/tt)%c;
LL ss=c/tt;
x=(x%ss+ss)%ss;
return x;
}
LL x,y,m,n,L;
int main()
{
while (~scanf("%lld%lld%lld%lld%lld",&x,&y,&m,&n,&L))
{
LL p=(L-(y-x+L)%L)%L,q=(n-m+L)%L;
LL r=calc(q,p,L);
if (r==-)puts("Impossible");
else printf("%lld\n",r);
}
}
poj 1061
[暑假集训--数论]poj1061 青蛙的约会的更多相关文章
- POJ1061 青蛙的约会 —— 扩展gcd
		
题目链接:https://vjudge.net/problem/POJ-1061 青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submi ...
 - poj1061 青蛙的约会 扩展欧几里德的应用
		
这个题解得改一下,开始接触数论,这道题目一开始是看了别人的思路做的,后来我又继续以这种方法去做题,发现很困难,学长告诉我先看书,把各种词的定义看懂了,再好好学习,我做了几道朴素的欧几里德,尽管是小学生 ...
 - POJ1061青蛙的约会[扩展欧几里得]
		
青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 108911 Accepted: 21866 Descript ...
 - POJ1061——青蛙的约会(扩展欧几里德)
		
青蛙的约会 Description两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面.它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止.可是它们出发之前忘记了一件 ...
 - POJ1061青蛙的约会(扩展欧几里德算法)
		
青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 102239 Accepted: 19781 Descript ...
 - POJ1061 青蛙的约会(扩展欧几里得)
		
题目链接:http://poj.org/problem?id=1061 青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submission ...
 - 解题报告:poj1061 青蛙的约会 - 扩展欧几里得算法
		
青蛙的约会 writer:pprp Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 119716 Accepted: 25238 ...
 - POJ1061 青蛙的约会 和 LOJ2721 「NOI2018」屠龙勇士
		
青蛙的约会 Language:Default 青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 133470 Accep ...
 - POJ-1061青蛙的约会,扩展欧几里德求逆元!
		
青蛙的约会 以前不止一次看过这个题,但都没有去补..好吧,现在慢慢来做. 友情提示 ...
 
随机推荐
- CUDA:Supercomputing for the Masses (用于大量数据的超级计算)-第九节
			
原文链接 第九节:使用CUDA拓展高等级语言 Rob Farber 是西北太平洋国家实验室(Pacific Northwest National Laboratory)的高级科研人员.他在多个国家级的 ...
 - 多线程中使用HttpContext.Current为null的解决办法
			
HttpContext.Current.Server.MapPath(logFile) 这个是得到具体路径的方法 正常情况下是可以的 多线程情况下就为null 下边的代码原本的作用是把网站的异常 ...
 - mac利用套件管理工具homebrew正确地同时安装python2.7和python3
			
MAC OSX 正確地同時安裝 PYTHON 2.7 和 PYTHON3 Python3 出來了(其實已經出來很久了,暈)!但是還是有很多 library 還是使用 Python2.7,所以要 ...
 - ASP.NET Core模块化前后端分离快速开发框架介绍之2、快速创建一个业务模块
			
源码地址 GitHub:https://github.com/iamoldli/NetModular 演示地址 地址:https://nm.iamoldli.com 账户:admin 密码:admin ...
 - yii2 RUL的生成
			
通常情况下,会使用 yii\helpers\Url 使用Url类来生成想要的URL地址(链接) Url提供的方法大都是静态方法,不需要对类进行实例化 1.1 最常用的 Url::to() 1.2. b ...
 - 怎么选取训练神经网络时的Batch size?
			
怎么选取训练神经网络时的Batch size? - 知乎 https://www.zhihu.com/question/61607442 深度学习中的batch的大小对学习效果有何影响? - 知乎 h ...
 - 将Excel文件转为csv文件的python脚本
			
#!/usr/bin/env python __author__ = "lrtao2010" ''' Excel文件转csv文件脚本 需要将该脚本直接放到要转换的Excel文件同级 ...
 - 大数运算:HDU-1042-N!(附N!位数的计算)
			
解题心得: 这里使用了10000进制.很明显,因为是n!所以单个最大的数是10000*10000,使用万进制. 可以借鉴高精度的加法,单个乘了之后在进位. 很坑的一点,0!=1,数学不好WA了三次,尴 ...
 - [BZOJ1187]神奇游乐园(插头DP)
			
Description 题意给定一个矩阵,每个格子有权值,在[-1000.1000]内,求一条回路使得回路经过权值和最大,每个格子最多经过一次 2≤n≤100,2≤m≤6 Code #include ...
 - greenplum-时间处理
			
工作中遇到,需要改变两周以前的数据状态,于是查了下资料,原来数据库直接就可以处理,所以分享给大家! 在PostgreSQL中可以直接对时间进行加减运算:. SELECT now()::timestam ...