设为首页 加入收藏

TOP

POJ 1061 青蛙绕地球约会-数论-(解一元一次同余方程+扩展欧几里得算法)
2015-11-21 00:54:47 来源: 作者: 【 】 浏览:1
Tags:POJ 1061 青蛙 地球 约会 数论 解一元 一次 方程 扩展 欧几 算法

题意:两只青蛙同向跳,起点是x,y,每次分别跳m,n米,地球周长是L,求最少跳几次相遇。

分析:

把式子写好就发现是一个一元一次同余方程。用扩展欧几里得算法来求。这题很基本得会。

代码:

?

#include
  
   
#include
   
     #include
    
      #include
     
       #include
      
        #include
       
         #define INF 1000000007 using 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<
        
         

?

?

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Codeforces Round #316 (Div. 2) .. 下一篇C++的PIMPL模式解析

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: