[USACO12FEB]Symmetry
传送门:
https://www.luogu.com.cn/problem/P3046
https://ac.nowcoder.com/acm/contest/6306/G
题意
给定n个不同的点,求这个点集有多少条对称轴
题解
对于一个点只有两种情况,一种是和另一个点关于这条线对称,一种是在对称轴上。
第一种情况:随机选择一个点p,枚举其他的点和他形成的对称轴,然后再判断这个对称轴是不是点集的对称轴。
第二种情况:当点在对称轴上时,要么另一个点 q 也在对称轴上,两点所在的直线是对称轴,这种情况直接判断这个对称轴是不是点集的对称轴。要么另一个点 q 关于这个点 p 所在的直线有对称点,这个时候按照第一种情况随机点为 q ,枚举其他点和他形成的对称轴,但是这个对称轴要经过点 p 。
想法很好理解,但是实现很难,在洛谷看到了一个题解,代码比较容易理解。
https://www.luogu.com.cn/blog/jzzcjb/dui-cheng-xing-symmetry-ti-xie
用到的数学结论
两点(x1,y1)(x2,y2)求过两点直线Ax+By+C=0
A=y2-y1 B=x1-x2 C=x2*y1-x1*y2 两点(x1,y1)(x2,y2)求两点间的对称轴Ax+By+C=0
A=x1-x2 B=y1-y2 C=-((x1+x2)(x1-x2)+(y1+y2)(y1-y2))/2 求(x',y')关于直线 Ax+By+C=0 的对称点(x0,y0)
设 k=-2*(A*x'+B*y'+C)/(A*A+B*B);
x0=x'+k*A;
y0=y'+k*B;
代码
优化了一下这个题解的代码,可以直接用set来记录一对点是否存在
1 #include<bits/stdc++.h>
2 #define eps 1e-6
3 using namespace std;
4
5 int n,cnt,x[100100],y[100100];
6 set<pair<int,int> >s;
7
8 bool dy(double x,double y){return ((x-y<=eps)||(y-x<=eps));}
9
10 bool is(double A,double B,double C){//判断某条直线是否是对称轴
11 for(int i=1;i<=n;i++){
12 /*
13 求(x',y')关于直线 Ax+By+C=0 的对称点(x0,y0)
14 设 k=-2*(A*x'+B*y'+C)/(A*A+B*B);
15 x0=x'+k*A;
16 y0=y'+k*B;
17 */
18 double k=-2*(double)(A*x[i]+B*y[i]+C)/(A*A+B*B);
19 double xo=x[i]+k*A;int xx=round(xo);
20 double yo=y[i]+k*B;int yy=round(yo);
21 if(!s.count({xx,yy})) return 0;
22 }
23 return 1;
24 }
25
26 bool check(int a,int b){ //以两点为一对对称点
27 //A=x1-x2 B=y1-y2 C=-((x1+x2)(x1-x2)+(y1+y2)(y1-y2))/2
28 double A=x[a]-x[b];
29 double B=y[a]-y[b];
30 double C=(double)-((x[a]*x[a]-x[b]*x[b])+(y[a]*y[a]-y[b]*y[b]))/2;
31 if(a!=1&&A*x[1]+B*y[1]+C!=0) return 0;
32 return is(A,B,C);
33 }
34
35 bool ok(int a,int b){ //以两点所在直线为对称轴
36 //A=y2-y1 B=x1-x2 C=x2*y1-x1*y2
37 int A=y[b]-y[a];
38 int B=x[a]-x[b];
39 int C=x[b]*y[a]-x[a]*y[b];
40 return is(A,B,C);
41 }
42
43 int main()
44 {
45 cin>>n;
46 for(int i=1;i<=n;i++) cin>>x[i]>>y[i],s.insert({x[i],y[i]});
47 for(int i=2;i<=n;i++) cnt+=check(1,i);
48 for(int i=2;i<n;i++) cnt+=check(i,n);
49 cout<<cnt+ok(1,n);
50 }
[USACO12FEB]Symmetry的更多相关文章
- bzoj2592: [Usaco2012 Feb]Symmetry
Description After taking a modern art class, Farmer John has become interested in finding geometric ...
- Symmetry(对称轴存在问题)
Symmetry Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Description Th ...
- fzu 2035 Axial symmetry(枚举+几何)
题目链接:fzu 2035 Axial symmetry 题目大意:给出n个点,表示n边形的n个顶点,判断该n边形是否为轴对称图形.(给出点按照图形的顺时针或逆时针给出. 解题思路:将相邻两个点的中点 ...
- [刷题]算法竞赛入门经典(第2版) 5-6/UVa1595 - Symmetry
题意:平面上给若干点,问它们是不是关于某垂直于x轴的直线对称. 代码:(Wrong Answer, –ms) //UVa1595 - Symmetry #include<iostream> ...
- rosetta对称性文件(rosetta symmetry file)的产生及应用
针对对称性PDB 3UKM,使用make_symmdef_file.pl脚本,可以执行产生对称单元及对称文件: $> $ROSETTA3/src/apps/public/symmetry/mak ...
- 洛谷P3048 [USACO12FEB]牛的IDCow IDs
P3048 [USACO12FEB]牛的IDCow IDs 12通过 67提交 题目提供者lin_toto 标签USACO2012 难度普及/提高- 时空限制1s / 128MB 提交 讨论 题解 ...
- Codeforces Round #127 (Div. 1) A. Clear Symmetry 打表
A. Clear Symmetry 题目连接: http://codeforces.com/contest/201/problem/A Description Consider some square ...
- 树形DP【洛谷P3047】 [USACO12FEB]附近的牛Nearby Cows
P3047 [USACO12FEB]附近的牛Nearby Cows 农民约翰已经注意到他的奶牛经常在附近的田野之间移动.考虑到这一点,他想在每一块土地上种上足够的草,不仅是为了最初在这片土地上的奶牛, ...
- 洛谷P3045 [USACO12FEB]牛券Cow Coupons
P3045 [USACO12FEB]牛券Cow Coupons 71通过 248提交 题目提供者洛谷OnlineJudge 标签USACO2012云端 难度提高+/省选- 时空限制1s / 128MB ...
随机推荐
- 【JavaWeb】AJAX 请求
AJAX 请求 什么是 AJAX AJAX(Asynchronous JavaScript And XMl),即异步 JS 和 XML.是指一种创建交互式网页应用的网页开发技术. AJAX 是一种浏览 ...
- LeetCode226 翻转二叉树
翻转一棵二叉树. 示例: 输入: 4 / \ 2 7 / \ / \ 1 3 6 9 输出: 4 / \ 7 2 / \ / \ 9 6 3 1 备注:这个问题是受到 Max Howell的 原问题 ...
- ThinkPHP5表单令牌刷新
制作登录页面的时候,加入了表单令牌,账号和密码输入错误后,再登录的话,会提示表单令牌错误, 这是因为旧的令牌已经过期了,我们要处理下前端的token,修复的办法,在路由文件下加入 //刷新表单令牌,然 ...
- requests+BeautifulSoup | 爬取电影天堂全站电影资源
import requests import urllib.request as ur from bs4 import BeautifulSoup import csv import threadin ...
- 【Oracle】整库导出后怎么恢复到指定用户的指定表
在导出的时候,整库导出 这里使用的是dba权限 $exp "'/ as sysdba'" file=full20180227.dmp log=exp_full20180227.lo ...
- 爬虫-使用lxml解析html数据
使用lxml之前,我们首先要会使用XPath.利用XPath,就可以将html文档当做xml文档去进行处理解析了. 一.XPath的简单使用: XPath (XML Path Language) 是一 ...
- idea 启动热部署Devtolls
1.在子工程pom.xml中添加devtools jar包到需要启动的项目中 1 <dependency> 2 <groupId>org.springframework.boo ...
- Redis 实战 —— 05. Redis 其他命令简介
发布与订阅 P52 Redis 实现了发布与订阅(publish/subscribe)模式,又称 pub/sub 模式(与设计模式中的观察者模式类似).订阅者负责订阅频道,发送者负责向频道发送二进制字 ...
- 前端工程构建之谈:gulp3要不要升级到Gulp4
关于升级还是不升级,这是一个哲学问题. gulp4的语法更加现代,支持ES6的大部分写法,使用exports的方式去暴露任务组合,更加灵活和便捷. gulp4同时也提供了很多强大的API,例如para ...
- Linux下nf_conntrack(最全面)_董明磊-CSDN博客_nf_conntrack https://blog.csdn.net/qq_35299863/article/details/79530732
Linux下nf_conntrack(最全面)_董明磊-CSDN博客_nf_conntrack https://blog.csdn.net/qq_35299863/article/details/79 ...