Cupid's Arrow[HDU1756]
Cupid's Arrow
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2301 Accepted Submission(s): 837
Problem Description
传说世上有一支丘比特的箭,凡是被这支箭射到的人,就会深深的爱上射箭的人。
世上无数人都曾经梦想得到这支箭。Lele当然也不例外。不过他想,在得到这支箭前,他总得先学会射箭。
日子一天天地过,Lele的箭术也越来越强,渐渐得,他不再满足于去射那圆形的靶子,他开始设计各种各样多边形的靶子。
不过,这样又出现了新的问题,由于长时间地练习射箭,Lele的视力已经高度近视,他现在甚至无法判断他的箭射到了靶子没有。所以他现在只能求助于聪明的Acmers,你能帮帮他嘛?
Input
本题目包含多组测试,请处理到文件结束。
在每组测试的第一行,包含一个正整数N(2<N<100),表示靶子的顶点数。
接着N行按顺时针方向给出这N个顶点的x和y坐标(0<x,y<1000)。
然后有一个正整数M,表示Lele射的箭的数目。
接下来M行分别给出Lele射的这些箭的X,Y坐标(0<X,Y<1000)。
Output
对于每枝箭,如果Lele射中了靶子,就在一行里面输出"Yes",否则输出"No"。
Sample Input
Sample Output
- #include <stdio.h>
- #include <string.h>
- #include <stdlib.h>
- #include <math.h>
- #include <algorithm>
- //#include <algorithm>
- namespace Geometry {
- #define eps (1e-8)
- class point {
- public:
- double x, y;
- point() {}
- point(const point &p): x(p.x), y(p.y) {}
- point(double a, double b): x(a), y(b) {}
- point operator + (const point & p)const {
- point ret;
- ret.x = x + p.x, ret.y = y + p.y;
- return ret;
- }
- point operator - (const point & p)const {
- point ret;
- ret.x = x - p.x, ret.y = y - p.y;
- return ret;
- }
- //dot product
- double operator * (const point & p)const {
- return x * p.x + y * p.y;
- }
- //cross product
- double operator ^ (const point & p)const {
- return x * p.y - p.x * y;
- }
- bool operator < (const point & p)const {
- if (fabs(x - p.x) < eps) {
- return y < p.y;
- }
- return x < p.x;
- }
- double mold() {
- return sqrt(x * x + y * y);
- }
- };
- double cp(point a, point b, point o) {
- return (a - o) ^ (b - o);
- }
- double dp(point a, point b, point o) {
- return (a - o) * (b - o);
- }
- class line {
- public:
- point A, B;
- line() {}
- line(point a, point b): A(a), B(b) {}
- bool IsLineCrossed(const line &l)const {
- point v1, v2;
- double c1, c2;
- v1 = B - A, v2 = l.A - A;
- c1 = v1 ^ v2;
- v2 = l.B - A;
- c2 = v1 ^ v2;
- if (c1 * c2 >= ) {
- return false;
- }
- v1 = l.B - l.A, v2 = A - l.A;
- c1 = v1 ^ v2;
- v2 = B - l.A;
- c2 = v1 ^ v2;
- if (c1 * c2 >= ) {
- return false;
- }
- return true;
- }
- };
- /*
- ** get the convex closure of dot set,store in array s.
- ** return the amount of the dot in the convex closure
- */
- int Graham(point * p, point * s, int n) {
- std::sort(p, p + n);
- int top, m;
- s[] = p[];
- s[] = p[];
- top = ;
- for (int i = ; i < n; i++) {
- while (top > && cp(p[i], s[top], s[top - ]) >= ) {
- top--;
- }
- s[++top] = p[i];
- }
- m = top;
- s[++top] = p[n - ];
- for (int i = n - ; i >= ; i--) {
- while (top > m && cp(p[i], s[top], s[top - ]) >= ) {
- top--;
- }
- s[++top] = p[i];
- }
- return top;
- }
- int dcmp(double x) {
- if (x < -eps) {
- return -;
- } else {
- return (x > eps);
- }
- }
- //if the point p0 on the segment consists of point p1 and p2
- int PointOnSegment(point p0, point p1, point p2) {
- return dcmp(cp(p1, p2, p0)) == && dcmp(dp(p1, p2, p0)) <= ;
- }
- /*
- ** if the point pt in polygon consists of the dots in array p
- ** 0:outside
- ** 1:inside
- ** 2:on the border
- */
- int PointInPolygon(point pt, point * p, int n) {
- int i, k, d1, d2, wn = ;
- p[n] = p[];
- for (i = ; i < n; i++) {
- if (PointOnSegment(pt, p[i], p[i + ])) {
- return ;
- }
- k = dcmp(cp(p[i + ], pt, p[i]));
- d1 = dcmp(p[i + ].y - pt.y);
- d2 = dcmp(p[i + ].y - pt.y);
- if (k > && d1 <= && d2 > ) {
- wn++;
- }
- if (k < && d2 <= && d1 > ) {
- wn--;
- }
- }
- return wn != ? : ;
- }
- }
- //using namespace Geometry;
- using namespace Geometry;
- point p[];
- int main() {
- #ifndef ONLINE_JUDGE
- freopen("input.txt", "r", stdin);
- #endif
- int n, m;
- while (scanf("%d", &n) != EOF) {
- for (int i = ; i < n; i++) {
- scanf("%lf%lf", &p[i].x, &p[i].y);
- }
- scanf("%d", &m);
- point pt;
- for (int i = ; i < m; i++) {
- scanf("%lf%lf", &pt.x, &pt.y);
- if (PointInPolygon(pt, p, n) == ) {
- printf("Yes\n");
- } else {
- printf("No\n");
- }
- }
- }
- return ;
- }
Cupid's Arrow[HDU1756]的更多相关文章
- HDU 1756 Cupid's Arrow 判断点在多边形的内部
Cupid's Arrow Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- hdu 1756:Cupid's Arrow(计算几何,判断点在多边形内)
Cupid's Arrow Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- HDU 1756 Cupid's Arrow 计算几何 判断一个点是否在多边形内
LINK:Cupid's Arrow 前置函数 atan2 返回一个向量的幅角.范围为[Pi,-Pi) 值得注意的是 返回的是 相对于x轴正半轴的辐角. 而判断一个点是否在一个多边形内 通常有三种方法 ...
- [HDU1756]Cupid's Arrow
题目大意: 给你一个简单多边形和若干个点,问每个点在多边形内还是外. 思路: 一开始没看清楚题,写了一个叉积法,事实上叉积法只能用来处理凸多边形与点的关系. 考虑一个射线法. 从这个点水平往左作一条射 ...
- HDU 1756 Cupid's Arrow( 判断点在多边形的内外 )
链接:传送门 思路:判断每支箭是否在多边形内,计算几何点定位中水题,不清楚下面的代码能不能适用于给定点的顺序不确定( 既不是顺时针又不是逆时针 ) /************************* ...
- 【HDOJ】1756 Cupid's Arrow
图论,点在多边形内部的判定. /* 1756 */ #include <iostream> #include <string> #include <map> #in ...
- HDU 1756 Cupid's Arrow (几何问题,判定点在多边形内部)
题意:中文的么,自己看喽. 析:很容易明白是判定点是不是在多边形内部,一般是向量来判定,我一开始用点在向量的右侧,因为是顺时针给的,只要点全在外侧或边上, 就可以,暴力一下就ok.由于这个是浮点数,一 ...
- ACM第一阶段学习内容
一.知识目录 字符串处理 ................................................................. 3 1.KMP 算法 .......... ...
- 下载恶意pcap包的网站
说几个我经常用的,免费的:1. Malware Traffic Analysis: http://www.malware-traffic-analysis.net/2018/index.htm ...
随机推荐
- layui 下拉框取值
layui.use('form', function () { var form = layui.form; form.on('select(Status)', function (data) { c ...
- C# for 遍历 IPagedList
IPagedList<Doc> ss = Doclist.ToPagedList(page, pageSize); ;i<ss.Count;i++) { var yy = ss[i] ...
- js-构造数组
js中,字符串的特性跟数组非常类似.数组是一种很重要的数据结构.在java中,数组声明的时候就要为其指定类型,数组中只能放同一种类型的数据.Js中的数组可以放不同的类型,但是是有序的,类似于java中 ...
- vue中引入json数据,不用本地请求
1.我的项目结构,需要在Daily.vue中引入daily.js中的json数据 2.把json数据放入一个js文件中,用exports导出,vscode的json格式太严格了,很多数据,调了一个多小 ...
- scrapy-redis使redis不止保存url
先看scrapy-redis源码 class RedisMixin(object): """Mixin class to implement reading urls f ...
- 【剑指Offer】56、删除链表中重复的结点
题目描述: 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4-> ...
- 51nod1256 乘法逆元【扩展欧几里得】
给出2个数M和N(M < N),且M与N互质,找出一个数K满足0 < K < N且K * M % N = 1,如果有多个满足条件的,输出最小的. Input 输入2个数M, N中间用 ...
- springcloud 中文文档
spring cloud 中文文档:https://springcloud.cc/spring-cloud-dalston.html spring cloud 中文网:https://springcl ...
- 0808关于RDS如何恢复到本地教程
转自http://www.cnblogs.com/ilanni/archive/2016/02/25/5218129.html 公司目前使用的数据库是阿里云的RDS,目前RDS的版本为mysql5.6 ...
- 实践一些js中的prototype, __proto__, constructor
<!DOCTYPE html> <html> <head> <title>ExtJs</title> <meta http-equiv ...