P1516 青蛙的约会

本文介绍了一道数学题,该题通过两只青蛙的运动规律找到它们相遇的时间点。文章给出了详细的数学推导过程,并使用拓展欧几里德算法来解决此问题。代码实现采用C++语言。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本题就是个数学题....我们要通过题目列出一个有解情况的方程。

第一只青蛙在跳了T次时是位于x+mt.

第二只青蛙同理是位于y+nt.

他们相遇便需要满足两者的差S是个整数,可列一方程:

(n-m)t+S=x-y

变成了一个ax+by=c形式,利用拓展欧几里德求解。

然后判断以下不存在解的情况,有解的话d=gcd(n-m,l),特解x1=x1(x-y)/d,通解为x1=x1(x-y)/d+k(l/d).

ans就是(x%(l/d)+l/d)%(l/d).

#include<iostream>
#include<cstdio>
using namespace std;
long long x,y,n,m,l;
void euclid(long long a,long long b, long long &d,long long &x,long long &y)
{
    if(!b)
    {
        x=1;y=0;d=a;
    }
    else 
    {
        euclid(b,a%b,d,x,y);
        int t=x;x=y;y=t-a/b*y;
    }
}
int main()
{
    long long a,b,d;
    scanf("%lld%lld%lld%lld%lld",&x,&y,&m,&n,&l);
    if(n<m)
    {
        swap(m,n);
        swap(x,y);
    }
    euclid(n-m,l,d,a,b);
    if((x-y)%d!=0 || m==n) printf("Impossible");
    else 
    {
        printf("%d",(a*(x-y)/d%(l/d)+(l/d))%(l/d));
    }
    return 0;
}

转载于:https://www.cnblogs.com/LSWorld/p/euclid1.html

青蛙约会”通常是一个经典的算法题或者是程序设计题目,在C语言中可以用于练习循环、条件判断以及简单的数学运算能力。 ### 题目背景: 两只青蛙在网上相识了,它们约定在线下见面。但是由于这两只青蛙分别位于两个不同的池塘边,并且只能按照一定的步长跳跃前进,因此需要计算出它们何时能够相遇。 假设第一只青蛙A从坐标X开始,每次跳跃M的距离;第二只青蛙B从坐标Y开始,每次跳跃N的距离。两条跑道长度都为L(即两蛙在一个环形轨道上运动)。求解两只青蛙经过多少次跳跃之后会首次相遇? --- #### 算法思路: 这是一个基于同余定理的问题。我们可以将其转化为寻找最小正整数t使得下面等式成立: ``` (X + t * M) % L == (Y + t * N) % L ``` 整理得到: ``` (t * M - t * N) % L = Y - X ``` 设 `D = M - N` 和 `R = Y - X`, 则问题变成找到满足 `(t * D) % L = R` 的最小非负整数`t`. 为了有效解决此方程,我们需要使用**扩展欧几里得算法**(Extended Euclidean Algorithm),通过它不仅可以验证是否有解还可以直接获得解答。 如果 gcd(D,L)|R (gcd代表最大公约数),则存在解决方案。否则无解,表示这两只青蛙永远无法相遇。 --- ##### C语言代码示例 ```c #include <stdio.h> // 扩展欧几里德算法 int ex_gcd(int a, int b, int *x, int *y){ if(b == 0){ *x = 1; *y = 0; return a; } else{ int r = ex_gcd(b, a%b, x, y); int temp = *x; *x = *y; *y = temp - a/b*(*y); return r; } } void frogMeeting(int x,int y,int m,int n,int l){ int d=m-n,r=y-x,g,x0,y0,k,t; g=ex_gcd(d,l,&x0,&y0); // 调用扩展欧几里德 if(r%g!=0){ // 如果r不是g的倍数,则无解 printf("They cannot meet.\n"); }else{ // 否则有解 k=r/g*x0; // 计算特解k*r/g=x0*(d/l)*l+r t=(long long)(l/g)*(k%(l/g)); // 最小正整数解 printf("Frogs will first meet after jumping for %lld times.",(unsigned long long)t); } } int main(){ int x=1,y=2,m=3,n=4,l=5; frogMeeting(x,y,m,n,l); return 0; } ``` 上述代码实现了利用扩展欧几里德算法求解两只青蛙在给定条件下多久能第一次相遇的功能。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值