[NOI2002] 荒岛野人
[NOI2002] 荒岛野人
题目描述
克里特岛以野人群居而著称。岛上有排列成环行的
每个野人
下面四幅图描述了一个有
奇怪的是,虽然野人有很多,但没有任何两个野人在有生之年处在同一个山洞中,使得小岛一直保持和平与宁静,这让科学家们很是惊奇。他们想知道,至少有多少个山洞,才能维持岛上的和平呢?
输入格式
第
第
输出格式
仅包含一个数
样例 #1
样例输入
3
1 3 4
2 7 3
3 2 1
样例输出
6
提示
保证
分析
读题
设
显然
这个野人的位置为
那么为了保持小岛的和平安定 对于
嘶~ 他很神奇
我们稍微导亿导
他很厉害!他不是一个有形的!
所以你读心经,观自在菩萨,行深般若波罗蜜多时,照见五蕴皆空。
注意,不死不灭,不垢不净,不增不减。
如如不动。
所以万物生于有,有生于无。
他不是一个实体!
你看他像什么
是不是这个↘
这是什么?
裴蜀定理哇
扩展欧几里得求解就完事了...........................吗?
咱这是不等号啊 人家裴蜀定理是等号
那咋办呢
不等式不就是相当于等式取反嘛
我们把导出来的式子换成等号求无解(野人压根遇不到)或求出来的
私货:多导有益于身心健康
code
Elaina's code
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define inf 0x3f
#define INF 1e9+100
#define mst(a,b) memset(a,b,sizeof(a))
#define re register
#define Elaina 0
const int N = 10000100;
inline int read(){
int x=0,f=1;
char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-1;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';
return x*f;
}
int t,n,m,mod,ans;
int s[N],p[N],l[N];
bool vis[N];
int exgcd(int a,int b,int &x,int &y){
if(!b){
x=1;
y=0;
return a;
}
int res=exgcd(b,a%b,x,y);
int t=x;
x=y;
y=t-a/b*y;
return res;
}
bool check(int m) {
for(int i=1;i<=n;++i){
for(int j=i+1;j<=n;++j){
int a=p[i]-p[j],b=m,c=s[j]-s[i],xx,yy;
int d=exgcd(a,b,xx,yy);
if(c%d){
continue;
}
a/=d,b/=d,c/=d;
if(b<0){
b=-b;
}
xx=(xx*c%b+b)%b;
if(xx<=l[i]&&xx<=l[j]){
return 0;
}
}
}
return 1;
}
main(){
scanf("%lld",&n);
int maxx=0;
for(re int i=1;i<=n;i++){
scanf("%lld%lld%lld",&s[i],&p[i],&l[i]);
maxx=max(maxx,s[i]);
}
for(re int i=maxx;;i++){
if(check(i)){
printf("%lld\n",i);
return Elaina;
}
}
return Elaina;
}
都看到这了,真的不点个赞吗(>ω<*)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本