首页 > 其他分享 >题解:P9957 [USACO20DEC] Stuck in a Rut B

题解:P9957 [USACO20DEC] Stuck in a Rut B

时间:2024-09-16 12:12:55浏览次数:1  
标签:ss int 题解 P9957 Stuck flag ans dir dis

由于 \(x, y \leq 10^9\),我们无法模拟每个时间段。因此,我们需要尝试判断两头牛何时会相交。

一个重要的观察是,牛不能后退,所以两头牛发生碰撞的唯一方式是 \(n[x] > e[x]\) 且 \(n[y] < e[y]\)。

可以按牛的起始坐标进行排序,然后模拟这些碰撞。

代码:

#include<bits/stdc++.h>
using namespace std;
bool flag_2;
int n;
struct s{//sheep
	int ans=INT_MAX;
	char dir;
	int x,y;
};
s ss[55];//sheeps
bool check(s,s);
void chuli(s&,s&);
bool check(s a,s b){//路径上是否有同一点
	if(a.dir==b.dir) return false;
	if(a.dir!='N') swap(a,b);
	if(a.x<=b.x) return false;
	if(b.y<=a.y) return false;
	return true;
}
void chuli(s &a,s &b){
	bool flag=false;
	if(a.dir!='N'){
		swap(a,b);
		flag=true;
	}
	int x=a.x;
	int y=b.y;
	int dis_a=abs(y-a.y);
	int dis_b=abs(x-b.x);
	if(a.ans<dis_a&&b.ans==dis_b) b.ans=INT_MAX,flag_2=true;//如果A判断为被B撞且B在撞A之前已经停下了
	if(b.ans<dis_b&&a.ans==dis_a) a.ans=INT_MAX,flag_2=true;
	if(dis_a<dis_b&&a.ans>=dis_a&&b.ans>dis_b)
		b.ans=dis_b,flag_2=true;
	if(dis_a>dis_b&&b.ans>=dis_b&&a.ans>dis_a)
		a.ans=dis_a,flag_2=true;
	if(flag) swap(a,b);
	return;
}
int main(){
	cin>>n;
	for(int i=1;i<=n;i++) cin>>ss[i].dir>>ss[i].x>>ss[i].y;
	while(true){
		flag_2=false;
		for(int i=1;i<=n;i++){
			for(int j=i+1;j<=n;j++){
				if(check(ss[i],ss[j]))
					chuli(ss[i],ss[j]);
			}
		}
		if(!flag_2) break;
	}
	for(int i=1;i<=n;i++)
		if(ss[i].ans!=INT_MAX) cout<<ss[i].ans<<'\n';
		else puts("Infinity");
	return 0;
}

标签:ss,int,题解,P9957,Stuck,flag,ans,dir,dis
From: https://www.cnblogs.com/cly312/p/18416168

相关文章

  • 题解:P3113 [USACO14DEC] Marathon G
    用线段树维护子路径的长度和这条子路径上删除一个点能够减少的最大距离。那么,修改就修改线段树上对应位置的值,查询就求这一段子路径的距离和子路径上删除一个点能够减少的最大距离,两者相减即可得到答案。代码:#include<bits/stdc++.h>usingnamespacestd;typedefpair<int,in......
  • 题解:P10961 划分大理石
    设\(f_x\)表示拼成\(x\)后,当前的大理石最多还能剩下几块,不能拼成就是\(-1\)。状态转移(当前考虑的大理石价值为\(i\),有\(x\)块):\(f_j=x(f_j\ge0)\)本来就可以拼成,那么现在的大理石都可以剩下。\(f_j=f_{j-i}-1(f_j=-1,j\gei,f_{j-i}>0)\)本来不能拼成,但用了一块就能拼......
  • AGC026D Histogram Coloring 题解
    [AGC026D]HistogramColoring题解给定\(n\)列的网格,每列高为\(h_i\),将每个格子染色成红色或蓝色,使得每个\(2\times2\)的区域都恰好有两个蓝格子和两个红格子,求方案数(对\(10^9+7\)取模)。\(1\leqn\leq100,1\leqh_i\leq10^9\)性质为了方便讲述,先假设\(h_i=h_{i+......
  • P2657 [SCOI2009] windy 数 题解
    枚举、预处理,len-1位,len位但小于第一个数的这些都不讲了,看这篇题解windy讲一下贴近最高位的处理。因为最高位如果取了,后面位数只能取到最高位,而不是9,而后面的数也是同理,所以我们的内部$\j\$循环枚举范围要把\(num_i\)单独拿出来判,单独拿出来的原因是好判break一些,因为已......
  • AGC005D ~K Perm Counting 题解
    [AGC005D]~KPermCounting题解如果一个排列\(P\)满足对于所有的\(i\)都有\(|P_i-i|\neqk\),则称排列\(P\)为合法的。现给出\(n\)和\(k\),求有多少种合法的排列。由于答案很大,请输出答案对\(924844033\)取模的结果。\(2\leqn\leq2\times10^3\),\(1\leqk\leqn......
  • P2602 [ZJOI2010] 数字计数 题解
    数位dp的板子题?显然\([a,b]\)等价于\([0,b]-[0,a]\)。考虑\(dp_{i,j}\)表示到第\(i\)位数字\(j\)的答案。先不考虑数字大小限制(即1到999之类),则显然有\(dp_{i,j}=dp_{i-1,j}\times10+10^{i-1}。当前数字是0时则减去10^{i-1},再减去1。\)所以我们可以预处理出\(dp\),来表示后面......
  • 图:207课程表 题解:入度数组,邻接表,队列,拓扑排序
    207.课程表-力扣(LeetCode)没做出来,参考题解,这篇题解写的非常好。把一个有向无环图转成线性的排序就叫 拓扑排序。(没太懂这句话的意思)classSolution{public:boolcanFinish(intnumCourses,vector<vector<int>>&prerequisites){vector<int>inDegre......
  • 【题解】【动态规划】—— [NOIP2006 普及组] 开心的金明
    【题解】【动态规划】——[NOIP2006普及组]开心的金明[NOIP2006普及组]开心的金明题目描述输入格式输出格式输入输出样例输入#1输出#1提示1.题意解析2.AC代码2.1.二维d......
  • 【题解】【模拟】—— [NOIP2008 普及组] ISBN 号码
    【题解】【模拟】——[NOIP2008普及组]ISBN号码[NOIP2008普及组]ISBN号码题目描述输入格式输出格式输入输出样例输入#1输出#1输入#2输出#2提示1.思路解析2.AC代码[NOIP2008普及组]ISBN号码通往洛谷的传送门题目描述每一本正式出版的图书都有一个I......
  • 【题解】—— [NOIP2011 普及组] 数字反转
    【题解】——[NOIP2011普及组]数字反转[NOIP2011普及组]数字反转题目描述输入格式输出格式输入输出样例输入#1输出#1输入#2输出#2提示1.思路解析2.AC代码[NOIP2011普及组]数字反转通往洛谷的传送门题目描述给定一个整数......