战争尾声
nowcoder 215073
题目大意
在平面直角坐标系(x,y范围均为1~200)上,给你n个点,让你找到一个点,使其到所有点直线距离相等(答案坐标均为整数)
解题思路
解题的关键在于“答案坐标均为整数”
有这个条件,可以直接枚举平面直角坐标系上的所有点(按x,y从大到小枚举,就可以使输出的点满足条件)
每枚举一个点,就计算一遍与给出的点连边的长度,如果都一样,那么输出这个点
代码
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define ll long long
using namespace std;
int n, g, x[210], y[210];
int main()
{
scanf("%d", &n);
for (int i = 1; i <= n; ++i)
scanf("%d%d", &x[i], &y[i]);
for (int i = 1; i <= 200; ++i)
for (int j = 1; j <= 200; ++j)
{
g = (i - x[1]) * (i - x[1]) + (j - y[1]) * (j - y[1]);//拿第一个点比较,直接勾股定理算平方,用平方比较
for (int k = 2; k <= n; ++k)
if (g != (i - x[k]) * (i - x[k]) + (j - y[k]) * (j - y[k]))
{
g = -1;//不相等
break;
}
if (g != -1)//如果没有不相等的就输出这个点
{
printf("%d %d", i, j);
return 0;//输出了就不用再找了
}
}
printf("War is cruel.");//都没找到就没有了
return 0;
}

京公网安备 11010502036488号