社区讨论

90分求助

P3958[NOIP 2017 提高组] 奶酪参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mi8672kx
此快照首次捕获于
2025/11/21 09:17
4 个月前
此快照最后确认于
2025/11/21 09:17
4 个月前
查看原帖
为什么单测一组(第四数据点第三组)能过,直接测第四组数据过不了; 代码
CPP
#include<iostream>
#include<fstream>
#include<cstdio>
using namespace std;
long long t,n,h,r,x[10001],y[10001],z[10001],p[1001][1001],f[10001];
int main(){
	cin>>t;
	for(long long i=1;i<=t;i++){
		cin>>n>>h>>r;
		long long c=0;
		for(long long j=1;j<=n;j++){
			cin>>x[j]>>y[j]>>z[j];
			if(z[j]<=r&&z[j]+r>=h){
				c=1;break;
			}
			if(z[j]<=r) p[i][j]=1;
			if(z[j]+r>=h) p[i][j]=2;
		}
		if(c==1) {
			f[i]=1;continue;
		}
		for(long long j=1;j<=n;j++){
			for(long long k=1;k<=n;k++){
				if((x[j]-x[k])*(x[j]-x[k])+(y[j]-y[k])*(y[j]-y[k])-4*r*r+(z[j]-z[k])*(z[j]-z[k])<=0){
					if((p[i][j]==1&&p[i][k]==2)||(p[i][j]==2&&p[i][k]==1)){
						c=1;break;
					} 
					if((p[i][j]==1&&p[i][k]==1)||(p[i][j]==2&&p[i][k]==2)) continue;
					if(p[i][j]==1) p[i][k]=1;
					if(p[i][k]==1) p[i][j]=1;
					if(p[i][j]==2) p[i][k]=2;
					if(p[i][k]==2) p[i][j]=2;
				}
			}
			if(c==1) break;
		}
		if(c==1) f[i]=1;
	}
	for(long long i=1;i<=t;i++) 
	if(f[i]==1) printf("Yes\n");
	else printf("No\n");
	return 0;
} 

回复

2 条回复,欢迎继续交流。

正在加载回复...