习题5-6 UVa1595-Symmetry

本题的难点是如何判断几个点组成的图形是否对称,只要能发现所有点的横坐标的和求平均数得到的横坐标恰好是对称轴所在的位置就好了。求出对称轴后再把各点到对称轴的距离求出来排序,这个问题就解决了。要注意对称轴和点到对称轴的距离可能不是整数。

题目链接:UVa 1595

AC代码:

#include <iostream>
#include <algorithm>
using namespace std;

const int maxn = 1000;
struct Point {
	int x, y;
	double dis;
	Point(int x = 0, int y = 0) :x(x), y(y) {}
}p[maxn];
bool cmp(const Point& a, const Point&b) {
	if(a.dis!=b.dis)
		return a.dis < b.dis;
	return a.y < b.y;
}

int main() {
	int T;
	cin >> T;
	while (T--) {
		int n;
		double sum = 0.0;
		bool flag = false;
		cin >> n;
		for (int i = 0; i < n; i++) {
			cin >> p[i].x >> p[i]. y;
			sum += p[i].x;
		}
		double sym = sum / n;  //求出理论上的对称轴的x值
		for (int i = 0; i < n; i++)
			p[i].dis = abs(p[i].x - sym);
		sort(p, p + n, cmp);
		for (int i = 0; i < n; i++) {
			if (!p[i].dis)
				continue;
			if (p[i].dis != p[i + 1].dis || p[i].y != p[i + 1].y) {
				flag = true;
				break;
			}
			i++;  //符合条件则跳到下一对
		}
		if (flag)
			cout << "NO" << endl;
		else
			cout << "YES" << endl;
	}
	return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值