社区讨论
P3958 蒟蒻90分求助
题目总版参与者 2已保存回复 5
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 5 条
- 当前快照
- 1 份
- 快照标识符
- @mi8677bd
- 此快照首次捕获于
- 2025/11/21 09:17 4 个月前
- 此快照最后确认于
- 2025/11/21 09:17 4 个月前
为什么单测一组(第四数据点第三组)能过,直接测第四组数据过不了;
代码
CPP#pragma GCC optimize(3)
#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])+(z[j]-z[k])*(z[j]-z[k])<=4*r*r){
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;
}
求大佬提出改进建议
回复
共 5 条回复,欢迎继续交流。
正在加载回复...