P2421-荒岛野人Savage题解
好久没写题解了啊
洛谷P2421 荒岛野人
题目大意:有一个有很多洞的岛上,住了
概括版:很多个青蛙的约会。
首先根据题目 我们可以得出一个式子:
其中
显然,如果上面的式子成立,说明这个结果食补满足题意的。
因此,我们的目的就可以简化为:求不满足上述式子的
当然,如果
题目给出
函数部分推导过程
由
得
移项可得
之后套入扩展欧几里得公式即可
#include<bits/stdc++.h>
#define fo(x,y,z) for(int (x)=(y);(x)<=(z);(x)++)
#define fu(x,y,z) for(int (x)=(y);(x)>=(z);(x)--)
using namespace std;
typedef long long ll;
inline int qr()
{
char ch=getchar();int x=0,f=1;
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*f;
}
#define qr qr()
const int Ratio=0;
const int N=25;
const int maxx=INT_MAX;
int n,m=0,ans;
int s[N],p[N],l[N];
int exgcd(int a,int b,int &x,int &y)
{
if(b==0)
{
x=1,y=0;
return a;
}
int c=exgcd(b,a%b,y,x);
y-=a/b*x;
return c;
}
bool check(int ii)
{
// cout<<i<<endl;
fo(i,1,n)
fo(j,i+1,n)
{
int c=s[i]-s[j],b=ii,a=p[j]-p[i],x,y;
int d=exgcd(a,b,x,y);
if(c%d)
continue;
a/=d,b/=d,c/=d;
if(b<0)
b=-b;
x=(x*c%b+b)%b;
//找到解 如果这两个人都还活着 就false
if(x<=l[i]&&x<=l[j])
return false;
}
return true;
}
int main()
{
// freopen("1.in","r",stdin);
// freopen("1.out","w",stdout);
n=qr;
fo(i,1,n)
s[i]=qr,p[i]=qr,l[i]=qr,m=max(m,s[i]);
for(int i=m;;i++)
if(check(i))
{
// cout<<i<<endl;
printf("%d\n",i);
break;
}
return Ratio;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】