POJ 1061 青蛙绕地球约会-数论-(解一元一次同余方程+扩展欧几里得算法)
来源:互联网 发布:淘宝搜索引擎工作流程 编辑:程序博客网 时间:2024/05/16 19:48
题意:两只青蛙同向跳,起点是x,y,每次分别跳m,n米,地球周长是L,求最少跳几次相遇。
分析:
把式子写好就发现是一个一元一次同余方程。用扩展欧几里得算法来求。这题很基本得会。
代码:
#include<iostream>#include<cstdio>#include<algorithm>#include<cstring>#include<string>#include<queue>#define INF 1000000007using namespace std;long long x,y,m,n,l;long long a,b,c,d;long long p,q,ans;long long gcd(long long a,long long b){if(b==0) return a;else return gcd(b,a%b);}void exgcd(long long a,long long b,long long &p,long long &q){if(b==0){p=1;q=0;return;}else{//exgcd(b,a%b,p,q); //注释掉的部分也是可行的//long long tmp=p;//p=q;//q=tmp-a/b*q;exgcd(b,a%b,q,p);q-=a/b*p;}}int main(){while(cin>>x>>y>>m>>n>>l){a=m-n;b=l;c=y-x;d=gcd(a,b);if(c%d){cout<<"Impossible"<<endl;}else{a/=d;b/=d;c/=d;exgcd(a,b,p,q);//cout<<p<<" "<<q<<endl;p*=c;ans=p%l;if(ans<0) ans+=l;cout<<ans<<endl;}}}
0 0
- POJ 1061 青蛙绕地球约会-数论-(解一元一次同余方程+扩展欧几里得算法)
- 青蛙的约会(扩展欧几里得解同余方程)
- POJ 1061 青蛙约会(一次同余方程)
- 20140714 「初等数论 - 拓展欧几里得+同余模方程」POJ 1061 青蛙的约会
- POJ 1061 青蛙的约会 一元线性同余方程
- Poj 1061 青蛙的约会 数论 欧几里得 求余方程
- POJ 1061 青蛙的约会(数论水题+求解模方程+扩展欧几里得算法)
- poj1061 青蛙的约会(扩展欧几里得算法求解同余方程)
- poj1061 青蛙的约会(扩展欧几里得算法求解同余方程)
- poj 1061 青蛙的约会 (线性同余,扩展欧几里得)
- POJ 1061 青蛙的约会(一元线性同余方程)
- 扩展欧几里得详解 NOIP2012同余方程 青蛙的约会
- POJ 1061 青蛙的约会(数论一元线性同余)
- poj 1061 青蛙的约会 (解同余方程)
- [数论]POJ 1061 青蛙的约会 扩展欧几里得算法
- poj 1061青蛙的约会 (数论:扩展的欧几里得算法)
- PKU1061 解题报告 青蛙的约会 __用扩展欧几里得解模同余方程
- POJ 2115 for求循环次数-数论-(同余方程+扩展欧几里得算法)
- 合并排序(递归)
- Scala 深入浅出实战经典 第6讲:Map、Tuple、Zip实战解析
- Scala 深入浅出实战经典 第7讲:Scala类的属性和对象私有字段实战详解
- Scala 深入浅出实战经典\第8讲:Scala主构造器、私有构造器、构造器重载实战详解
- Scala 深入浅出实战经典 第9讲:Scala的内部类实战详解
- POJ 1061 青蛙绕地球约会-数论-(解一元一次同余方程+扩展欧几里得算法)
- [C++]学习札记2015-08-14
- hdu1276(士兵队列训练问题) java集合水过
- multisim13安装破解
- svn 冲突
- Java 将excel中的内容导入数据库中
- 腾讯面试专场
- 面试题五: 从尾到头打印链表
- POJ 2115 for求循环次数-数论-(同余方程+扩展欧几里得算法)