首页 > 其他分享 >[NOI2002] 荒岛野人

[NOI2002] 荒岛野人

时间:2024-03-28 16:22:49浏览次数:28  
标签:ch int 荒岛 leq 野人 NOI2002 neq define

[NOI2002] 荒岛野人

传送门

题目描述

克里特岛以野人群居而著称。岛上有排列成环行的 \(m\) 个山洞。这些山洞顺时针编号为 \(1,2,\dots ,m\) 。岛上住着 \(n\) 个野人,一开始依次住在山洞 \(C_1,C_2,\dots ,C_n\)中,以后每年,第 \(i\) 个野人会沿顺时针向前走 \(P_i\) 个洞住下来。

每个野人 \(i\) 有一个寿命值 \(L_i\),即生存的年数。

下面四幅图描述了一个有 \(6\) 个山洞,住有三个野人的岛上前四年的情况。三个野人初始的洞穴编号依次为 \(1,2,3\);每年要走过的洞穴数依次为 \(3,7,2\);寿命值依次为 \(4,3,1\)。

奇怪的是,虽然野人有很多,但没有任何两个野人在有生之年处在同一个山洞中,使得小岛一直保持和平与宁静,这让科学家们很是惊奇。他们想知道,至少有多少个山洞,才能维持岛上的和平呢?

输入格式

第 \(1\) 行为一个整数 \(n(1\leq n\leq 15)\),即野人的数目。

第 \(2\) 行到第 \(N+1\) 每行为三个整数 \(C_i, P_i, L_i (1\leq C_i,P_i \leq 100, 0\leq L_i\leq 10^6 )\),表示每个野人所住的初始洞穴编号,每年走过的洞穴数及寿命值。

输出格式

仅包含一个数 \(M\),即最少可能的山洞数。输入数据保证有解,且 \(M\) 不大于 \(10^6\)。

样例 #1

样例输入

3
1 3 4
2 7 3
3 2 1

样例输出

6

提示

\(1\leq N\leq 15\),\(1\leq C_i,P_i\leq 100\),\(0\leq L_i\leq 10^6\)

保证 \(M\leq 10^6\)

分析

读题

设\(i\)表示第\(i\)个野人 \(x\)表示第\(x\)年

显然

这个野人的位置为

\[(c[i]+p[i]*x) \% m \]

那么为了保持小岛的和平安定 对于\(i,j\)两个野人,他们在第\(x\)年 有不等式

\[(c[i]+p[i]*x) \% m \neq(c[j]+p[j]*x) \% m \]

嘶~ 他很神奇

我们稍微导亿导

\[(c[i]+p[i]*x)\%m \neq (c[j]+p[j]*x)\%m \]

\[c[i]+p[i]*x+m*k_1 \neq c[j]+p[j]*x+m*k_2 \]

\[p[i]*x-p[j]*x+m*k_1-m*k_2 \neq c[j]-c[i] \]

\[(p[i]-p[j])*x+(k_1-k_2)*m \neq c[j]-c[i] \]

他很厉害!他不是一个有形的!
所以你读心经,观自在菩萨,行深般若波罗蜜多时,照见五蕴皆空。
注意,不死不灭,不垢不净,不增不减。
如如不动。
所以万物生于有,有生于无。
他不是一个实体!
你看他像什么
是不是这个↘

\[a*x_1+b*y_1=z=gcd(a,b) \]

这是什么?
裴蜀定理哇
扩展欧几里得求解就完事了...........................吗?
咱这是不等号啊 人家裴蜀定理是等号
那咋办呢

不等式不就是相当于等式取反嘛

我们把导出来的式子换成等号求无解(野人压根遇不到)或求出来的\(最小非负整数解 \geq min(l_i,l_j)\)(其中一个已经死翘翘了)的情况不就完事了嘛~

私货:多导有益于身心健康

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;
}

都看到这了,真的不点个赞吗(>ω<*)

标签:ch,int,荒岛,leq,野人,NOI2002,neq,define
From: https://www.cnblogs.com/Elaina-0/p/18101990

相关文章

  • 荒岛野人Savage
    题目描述样例31342733216分析首先,我们先设4个变量,初始坐标d[i],每年步数p[i],寿命l[i],根据题目很容易得到一个不等式(假设i,j是两个野人的标号,x为经过的年数):(d[i]+p[i]*x)%m!=(d[j]+p[j]*x)%m。解不等式。。。不会,但可以转化一下,把不等式转为等......
  • P2421-荒岛野人Savage题解
    好久没写题解了啊洛谷P2421荒岛野人题目大意:有一个有很多洞的岛上,住了\(n\)个野人,每个野人的初始位置为\(c[i]\),换洞的速度为\(p[i]\),寿命为\(l[i]\)。要求求出洞的最少个数\(M\)满足每个野人在生存状态下不会在同一年和其他野人住在同一个山洞里。概括版:很多个青蛙的约会。......
  • 洛谷题单指南-线性表-P2234 [HNOI2002] 营业额统计
    原题链接:https://www.luogu.com.cn/problem/P2234题意解读:要计算每一天最小波动值的和,需要对每一天求最小波动值,再求和,如果暴力法,时间复杂度在1+2+3+......+32767≈5*10^8,可能会超时。解题思路:1、暴力法:由于本题测试数据比较水,实测暴力求解直接可以AC,由于没有技术含量,不做具体......
  • P2234 [HNOI2002] 营业额统计
    P2234[HNOI2002]营业额统计题解思路对原数组排序,记录下排序前的位置。对排序后的数组构造链表。从原数组的\(n\)往\(1\)枚举,比较排序生成链表中该元素的前驱或后继与该元素差值的最小值,加入答案。在排序生成的链表中删除该元素。正确性的疑惑一开始很困惑,难道排序......
  • [NOI2002]银河英雄传说
    银河英雄传说TJ题目背景公元5801年,地球居民迁至金牛座第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展。宇宙历799年,银河系的两大军事集团在巴米利恩星域爆发战争。泰山压顶集团派宇宙舰队司令莱因哈特(B)率领十万余艘战舰出征,气吞山河集团点名......
  • 题解 P2229 【[HNOI2002]沙漠寻宝】
    postedon2021-06-0112:15:15|under题解|source这题一看就知道是个模拟。做模拟题的时候,一定要先确保你的程序能跑出正确的结果,再去想优化时间。这道题还是很简单的,让我们开始吧:读入我们把输入离线,拿string存起来。如果不离线,那loop就会很难处理,加大难度。intn;......
  • 题解 P2276 [HNOI2002]农场的果树
    首先可以观察出一颗\(n\)个节点的二叉树,当其字典序最小的时候,其形态为一条向右偏的链,当其字典序最大的时候,是一条向左偏的链。由于每一种编码对应唯一的一颗二叉树,我们可以先建树。然后考虑树上分治,尝试以下三种方式:变大右子树的字典序变大左子树的字典序,并将右子树变成......
  • 【DS】P9062 [Ynoi2002] Adaptive Hsearch&Lsearch(区间最近点对)
    ProblemLink给定平面上\(n\)个点,\(Q\)次询问编号在\([l,r]\)内的点的最近点对。\(n,Q\le2.5\times10^5\)。技巧:平面网格化乱搞都是错的。看见欧几里德距离,想到平面网格化。考虑一个平面最近点对的网格化做法:随机点的顺序,按顺序依次考虑,考虑到第\(i\)个点时,设当前最......
  • 森林之子野人怎么吃 怎么烤肉_森林2森林之子攻略
    咦,在这圣索弗朗代兰县的丛林当今世界,想活留下来要是懂冒险。《丛林之母》格斗游戏中,他们要直面雪人的突袭,也要补足食材,因此间接杀掉雪人当郊游也是极好的优先选择。所以丛林之母呢吃雪人呢?丛林之母雪人呢吃:在《丛林之母》中,玩者在击破雪人后能吃雪人来补足食材,但是无法间接吃遗......
  • P1196 [NOI2002] 银河英雄传说
    有一个30000*N(i)的列队,2种操作1.Mi,j   i行移动到j行的末尾2.Ci,j  询问i行和j行的距离(如果在同一列) #include<bits/stdc++.h>usingnamespacestd;......