NC16417. [NOIP2017]奶酪
描述
输入描述
每个输入文件包含多组数据。
输入文件的第一行,包含一个正整数 T,代表该输入文件中所含的数据组数。
接下来是 T 组数据,每组数据的格式如下:
第一行包含三个正整数 n, h 和 r, 两个数之间以一个空格分开,分别代表奶酪中空洞的数量,奶酪的高度和空洞的半径。
接下来的 n 行,每行包含三个整数 x, y, z, 两个数之间以一个空格分开, 表示空洞球心坐标为 (x,y,z)。
输出描述
输出文件包含 T 行,分别对应 T 组数据的答案,如果在第 i 组数据中, Jerry 能从下表面跑到上表面,则输出“Yes”,如果不能,则输出“No”(均不包含引号)。
示例1
输入:
3 2 4 1 0 0 1 0 0 3 2 5 1 0 0 1 0 0 4 2 5 2 0 0 2 2 0 4
输出:
Yes No Yes
说明:
C++(clang++ 11.0.1) 解法, 执行用时: 194ms, 内存消耗: 444K, 提交时间: 2022-11-25 09:09:11
#include<bits/stdc++.h> using namespace std; int t,n,h,r,f[1234],x[1234],y[1234],z[1234],a; long long xx(int p){return 1ll*p*p;} int fu(int p){ if(f[p]==p)return p; return f[p]=fu(f[p]); } int main(){ cin>>t; while(t--){ cin>>n>>h>>r,a=0; for(int i=0;i<n;i++){ cin>>x[i]>>y[i]>>z[i];f[i]=i; for(int j=0;j<i;j++)if(xx(x[i]-x[j])+xx(y[i]-y[j])+xx(z[i]-z[j])<=4ll*r*r)f[fu(j)]=i; } for(int i=0;i<n;i++)for(int j=0;j<n;j++)if(fu(i)==fu(j)&&z[i]<=r&&z[j]>=h-r)a=1; if(a)puts("Yes"); else puts("No"); } }