1 条题解
-
0
自动搬运
来自洛谷,原作者为

Siyuan
Dream OIer.搬运于
2025-08-24 21:37:31,当前版本为作者最后更新于2019-02-08 11:04:13,作者可能在搬运后再次修改,您可在原文处查看最新版自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多
以下是正文
Description
题目链接:Luogu 2421
克里特岛以野人群居而著称。岛上有排列成环行的 个山洞。这些山洞顺时针编号为 。岛上住着 个野人,一开始依次住在山洞 中。以后每年,第 个野人会沿顺时针向前走 个洞住下来。每个野人i有一个寿命值 ,即生存的年数。
奇怪的是,虽然野人有很多,但没有任何两个野人在有生之年处在同一个山洞中,使得小岛一直保持和平与宁静,这让科学家们很是惊奇。他们想知道,至少有多少个山洞,才能维持岛上的和平呢?数据保证有解, 的值不大于 。
数据范围:,,
Solution
我们形象化地描述题意:
求最小的 使得对于任意的 使得如下同余方程无解:
$$C_i+xP_i\equiv C_j+xP_j\pmod M\quad (x>\min(L_i,L_j)) $$我们发现题目中保证 ,那么我们可以考虑枚举 并对这 个同余方程利用 来求解并判断。
时间复杂度:
Code
#include <cstdio> #include <algorithm> const int N=20; int n,s[N],p[N],l[N]; int exgcd(int a,int b,int &x,int &y) { if(!b) {x=1,y=0;return a;} int d=exgcd(b,a%b,y,x); y-=a/b*x; return d; } 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],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; if(x<=l[i]&&x<=l[j]) return 0; } return 1; } int main() { scanf("%d",&n); int mx=0; for(int i=1;i<=n;++i) scanf("%d%d%d",&s[i],&p[i],&l[i]),mx=std::max(mx,s[i]); for(int i=mx;;++i) if(check(i)) return printf("%d\n",i),0; return 0; }
- 1
信息
- ID
- 1429
- 时间
- 1000ms
- 内存
- 125MiB
- 难度
- 5
- 标签
- 递交数
- 0
- 已通过
- 0
- 上传者