题目描述
据传,2020年是宇宙射线集中爆发的一年,这和神秘的宇宙狗脱不了干系!但是瑞神和东东忙于正面对决宇宙狗,宇宙射线的抵御工作就落到了ZJM的身上。假设宇宙射线的发射点位于一个平面,ZJM已经通过特殊手段获取了所有宇宙射线的发射点,他们的坐标都是整数。而ZJM要构造一个保护罩,这个保护罩是一个圆形,中心位于一个宇宙射线的发射点上。同时,因为大部分经费都拨给了瑞神,所以ZJM要节省经费,做一个最小面积的保护罩。当ZJM决定好之后,东东来找ZJM一起对抗宇宙狗去了,所以ZJM把问题扔给了你
输入描述
输入 第一行一个正整数N,表示宇宙射线发射点的个数
接下来N行,每行两个整数X,Y,表示宇宙射线发射点的位置
输出描述
输出包括两行第一行输出保护罩的中心坐标x,y 用空格隔开。
第二行输出保护罩半径的平方
(所有输出保留两位小数,如有多解,输出x较小的点,如扔有多解,输入y较小的点)。
无行末空格。
问题分析
因为中心位于一个宇宙射线的发射点上,所以只需要枚举求宇宙射线的发射点到其他宇宙发射点的距离最大值,其中的最小值就是要求的保护罩半径。注意要求输出的是半径的平方!
这道题考场上全WA,其实错的很可惜,让保留2位小数,就以为是半径,根本没看到题目中让求得是半径的平方。所以,以后一定要认真读题,看清楚题目要求。
#include<stdio.h>
#include<math.h>
using namespace std;
double a[1010],b[1010];
double t[1010][1010];
int main(){
int n,p=0;
double ans=0;
scanf("%d",&n);
for(int i=0;i<n;i++)
scanf("%lf%lf",&a[i],&b[i]);
for(int i=0;i<n;i++)
for(int j=i+1;j<n;j++)
t[i][j]=(a[i]-a[j])*(a[i]-a[j])+(b[i]-b[j])*(b[i]-b[j]);
for(int i=1;i<n;i++)
if(t[0][i]>ans)ans=t[0][i];
for(int i=1;i<n;i++){
double tt=0;
for(int j=0;j<i;j++)
if(t[j][i]>tt)tt=t[j][i];
for(int j=i+1;j<n;j++)
if(t[i][j]>tt)tt=t[i][j];
if(tt<ans){
ans=tt;
p=i;
}
else if(tt==ans){
if(a[i]<a[p] ||(a[i]==a[p] && b[i]<b[p]))p=i;
}
}
printf("%.2lf %.2lf\n%.2lf",a[p],b[p],ans);
return 0;
}