题目链接:fzu 2035 Axial symmetry

题目大意:给出n个点,表示n边形的n个顶点,判断该n边形是否为轴对称图形。(给出点按照图形的顺时针或逆时针给出。

解题思路:将相邻两个点的中点有序的加入点集,即保证点是按照图形的顺时针或逆时针出现的,然后枚举i和i + n两点的直线作为对称轴。判断其他所有点是否对称即可。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h> const int N = 1005;
const double eps = 1e-9; struct point {
double x, y;
void get() { scanf("%lf%lf", &x, &y); }
void set(double a, double b) { x = a, y = b; }
bool operator == (const point& c) {
return fabs(x - c.x) < eps && fabs(y - c.y) < eps;
}
}p[N]; int n, vis[N]; void init() {
scanf("%d", &n);
p[0].get();
int t; for (int i = 1; i < n; i++) {
t = i * 2;
p[t].get();
p[t - 1].set((p[t - 2].x + p[t].x) / 2, (p[t - 2].y + p[t].y) / 2);
}
t = (n - 1) * 2;
p[t + 1].set((p[t].x + p[0].x) / 2, (p[t].y + p[0].y) / 2);
} void findLine(double& A, double& B, double& C, const point& u, const point& v) {
A = v.y - u.y;
B = u.x - v.x;
C = u.y * (v.x - u.x) + (u.y - v.y) * u.x;
} point findPoint(double A, double B, double C, point k) { point c;
c.x = ( (B * B - A * A) * k.x - 2 * A * B * k.y - 2 * A * C ) / (A * A + B * B);
c.y = (-2 * A * B * k.x + (A * A - B * B)* k.y - 2 * B * C) / (A * A + B * B);
return c;
} bool search(point k) {
for (int i = 0; i < n; i++) { if (vis[i * 2]) continue; if (p[i * 2] == k) {
vis[i * 2] = 1;
return true;
}
}
return false;
} bool judge(double A, double B, double C) { for (int i = 0; i < n; i++) { if (vis[i * 2]) continue; point k = findPoint(A, B, C, p[i * 2]); if (!search(k)) return false;
}
return true;
} bool solve() {
double A, B, C;
for (int i = 0; i < n; i++) {
findLine(A, B, C, p[i], p[i + n]); memset(vis, 0, sizeof(vis));
vis[i] = vis[i + n] = 1; if (judge(A, B, C) ) return true;
}
return false;
} int main () {
int cas;
scanf("%d", &cas);
for (int i = 1; i <= cas; i++) {
init();
printf("Case %d: %s\n", i, solve() ? "YES" : "NO");
}
return 0;
}

fzu 2035 Axial symmetry(枚举+几何)的更多相关文章

  1. UVALive 6092 Catching Shade in Flatland --枚举+几何计算

    题意:x=[-200,200],y=[-200,200]的平面,一天中太阳从不同角度射到长椅(原点(0,0))上,有一些树(用圆表示),问哪个时刻(分钟为单位)太阳光线与这些圆所交的弦长总和最长.太阳 ...

  2. FZU 2140 Forever 0.5 (几何构造)

    Forever 0.5 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit  ...

  3. NAIPC-2016

    A. Fancy Antiques 爆搜+剪枝. #include <bits/stdc++.h> using namespace std ; typedef pair < int ...

  4. Logistic Regression - Formula Deduction

    Sigmoid Function \[ \sigma(z)=\frac{1}{1+e^{(-z)}} \] feature: axial symmetry: \[ \sigma(z)+ \sigma( ...

  5. FZU 1018 枚举dp

    题意 给出一个数字组成的立方体 在其中选取一个体 使这个体中的数字之和最小 不可以不选 fzu的题目分类动态规划里面不是按难度排得 是按照题号..记得以前做题碰到过算 矩阵里面求子矩阵的最大和的 不会 ...

  6. FZU 2125 简单的等式 【数学/枚举解方程式】

    现在有一个等式如下:x^2+s(x,m)x-n=0.其中s(x,m)表示把x写成m进制时,每个位数相加的和.现在,在给定n,m的情况下,求出满足等式的最小的正整数x.如果不存在,请输出-1. Inpu ...

  7. ACM: FZU 2110 Star - 数学几何 - 水题

     FZU 2110  Star Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u  Pr ...

  8. POJ 3304 Segments --枚举,几何

    题意: 给n条线段,问有没有一条直线,是每条线段到这条直线上的投影有一个公共点. 解法: 有公共点说明有一条这条直线的垂线过所有线段,要找一条直线过所有线段,等价于从所有线段中任选两端点形成的直线存在 ...

  9. 简单几何(凸包+枚举) POJ 1873 The Fortified Forest

    题目传送门 题意:砍掉一些树,用它们做成篱笆把剩余的树围起来,问最小价值 分析:数据量不大,考虑状态压缩暴力枚举,求凸包以及计算凸包长度.虽说是水题,毕竟是final,自己状压的最大情况写错了,而且忘 ...

随机推荐

  1. java多线程制作计时器

    基本思路: 在类中创建thread 供按钮监听器调用. 界面设计:

  2. shell一些笔记

    1.getopts可以编写脚本,使控制多个命令行参数更加容易 如:文件get.sh #! /bin/sh NAME=false AGE=false ODD=false SEX=false while ...

  3. ThinkPHP - CURD增删改查操作

    public function show(){ //使用model模型 //1.可以使用 $user = new Model('User'); //2.可以使用 $user = M('User'); ...

  4. python——登陆接口设计(循环方法)

    近日重新整理了登陆接口设计程序,感觉以前的代码没有注释,让园子的其他童鞋读起来比较费劲.也没有流程图和程序运行说明. 1.流程图 2.user_file.txt&lock_file.txt文件 ...

  5. HDU 5012 Dice DFS

    简单DFS //#pragma comment(linker, "/STACK:16777216") //for c++ Compiler #include <stdio.h ...

  6. 简单cpu处理器

    在135例中有一个简单处理器的程序,稍作修改成自己的风格 //date :2013/8/22 //designer :pengxiaoen //function get a mpc with veri ...

  7. zk create() 方法

    create() $path = $zkh->create($req_path, $data); $path = $zkh->create($req_path, $data, 'flags ...

  8. SVProgressHUD的使用

    GitHub:https://github.com/samvermette/SVProgressHUD SVProgressHUD和MBProgressHUD效果差点儿相同,只是不须要使用协议,同一时 ...

  9. Xcode的Hello World(简单易懂)

    http://www.cocoachina.com/industry/20131121/7392.html http://objccn.io/issue-6-3/

  10. 在MAC系统里添加开机启动任务(但是怎么才能知道自己程序的固定位置呢?)

    公司最近购进了几台MAC台式电脑,要在上面为一个项目做测试. MAC这么高大上的东西,还是第一次接触,折腾了半天好不容易安装了一些需要的应用服务上去,跑了一下还不错. 公司提倡节约用电,下班之后要把所 ...