HDU-2108 Shape of HDU判断凸多边形(叉积) Apare

HDU-2108 Shape of HDU判断凸多边形(叉积)

xzc 2019.5.21

HDU题目链接<-
题意:

  给出n边形按逆时针排好序的n个顶点,判断是否是凸多边形

Sample input
4
0 0 1 0 1 1 0 1
0
Sample output
convex

叉积的性质:
  1. 设向量a = (x1,y1), b = (x2,y2)
  2. 令c = a * b, 那么c是一个向量,方向垂直于a,b所在的平面
  3. C = x1 * y2 - x2 * y1
  4. |C|表示以向量a,b为邻边的平行四边形的面积
  5. C的正负也是有几何意义的
  • 若C > 0, 表示向量b在向量a的逆时针方向
  • 若C < 0, 表示向量b在向量a的瞬时真方向
  • 若C = 0, 表示向量b和向量a共线

我们最常用的就是性质4和性质5了
  1. 性质4课以用来求三角形的面积
  2. 性质5可以用来判断凸多边形,求凸包,判断线段相交

判断凸多边形的方法之一:
  1. 对所有顶点按照到原点或者某个点逆时针排序(题目已经给排好了)
  2. 设排好序的点为P1,P2,P3…Pn,p1,p2(循环的)
  3. 那么对于1到n的每个点Pi,它后面两个点为Pi+1和Pi+2,我们构造两个向量:
    a = (pi+1.x - pi.x  , pi+1.y - pi.y  )
    b = (pi+2.x - pi+1.x, pi+2.y - pi+1.y)
    那么如果a * b的结果小于零,说明不是凸多边形

代码
/*
Submit Time 	    Judge Status	Pro.ID	Exe.Time	Exe.Memory	Code Len.	Language	Author
2019-05-21 19:10:12	Accepted	    2108	15MS	    1380K	    724 B	    G++	        apareHDU
*/
#include <bits/stdc++.h>
using namespace std;
bool ok(pair<int,int> p1,pair<int,int> p2,pair<int,int>p3)
{
   
    int x1 = p2.first - p1.first;
    int y1 = p2.second - p1.second;
    int x2 = p3.first - p2.first;
    int y2 = p3.second - p2.second;
    return 1ll*x1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值