编程之美读书笔记_4.4_是否在三角形内
来源:互联网 发布:矩阵关联分析法excel 编辑:程序博客网 时间:2024/05/16 11:19
对几何题目,常用到矢量。若P点在三角形内部,则矢量PA沿时钟某个方向三次旋转分别经过PB、PC再回到 PA,每次旋转角度都不会超过180度。即PA×PB、PB×PC和PC×PA这三个矢量积应该都为正,或都为负。如果P在三角形边上,则这三个矢量积应该一个为0,其它两个同正或同负。若在三角形某个顶点,则三个矢量积,必有两个为 0 ,一个不为 0 。若ABC 三点共线, P在这直线上,则所有矢量积均为0 ,若P不在这直线上,则为两正一负或两负一正 。
struct Point{
double x;
double y;
};
int direction(const Point& a, const Point& b, const Point& p)
{
const double zero=1e-6;
double tmp=(p.x-a.x)*(p.y-b.y)-(p.x-b.x)*(p.y-a.y);
if (tmp > zero) return 1;
if (tmp < -1*zero) return 4;
return 0;
}
bool is_in_triangle(const Point& a, const Point& b, const Point& c, const Point& p)
{
int t= direction(a,b,p)+ direction(b,c,p) + direction(c,a,p);
/*
if (t==3 || t==12) return true; //在三角形ABC内
if (t==1 || t==4) return true; //与点A B C之一重合
if (t==2 || t==8) return true; //在三角形ABC边上。
*/
if (t>=1 && t<=4) return true;
if (t==8 || t==12) return true;
return false;
//在三角形内a[3]=a[12]=1 在边上 a[2]=a[8]=1 在顶点a[1]=a[4]=1;
//int a[]={0, 1,1,1,1, 0,0,0, 1, 0,0,0, 1};
//return a[direction(a,b,p)+direction(b,c,p)+direction(c,a,p)];
}
- 编程之美读书笔记_4.4_是否在三角形内
- 编程之美读书笔记_4.4_是否在三角形内
- 读书笔记之编程之美 - 4.4 点是否在三角形内
- 编程之美4.4 判断点是否在三角形内
- 编程之美: 点是否在三角形内
- 编程之美读书笔记_4.1_金刚坐飞机问题
- 编程之美:第四章 数字之趣 4.4点是否在三角形内
- 编程之美4.4点是否在三角形内扩展问题
- 编程之美-判断点是否在三角形内方法整理
- 编程之美读书笔记_4.5_磁带文件存放优化
- 编程之美读书笔记_4.5_磁带文件存放优化
- 编程之美4.4——点在三角形内
- 编程之美读书笔记_杂项
- 是否在三角形内
- 读书笔记之编程之美 - 4.8 三角形测试用例
- 点是否在三角形内
- 点是否在三角形内
- 编程之美读书笔记_3.9_重建二叉树
- rev命令可以实现文件文本行,或字符串的反序显示
- jquery是有平台无关性的吧。为什么我在ie浏览器上可以运行,在火狐上运行不了呢?求帮助?有
- 面试70问经典回答
- 优化php代码有40条技巧
- MySQL数据库性能进行优化三大绝招
- 编程之美读书笔记_4.4_是否在三角形内
- 坚持每天学英语10分钟,5年弹指一挥间
- The first decord
- c++获取当前路径 向黑客迈进!!!
- MyEclipse格式化代码设置
- 中缀表达式转换后缀表达式---算法
- SQL中获取当天,当月信息
- 如果赢得繁华,失去一个人
- Flex与ACtionSCript关系揭秘