战争尾声
战争尾声
https://ac.nowcoder.com/acm/contest/11038/A
战争尾声
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; }