几何算法库.doc

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
几何算法库

const double INF=1e100; const double ZERO=1e-6; const double PI=2*asin(1.0); struct XYpoint{ //(x,y) double x; double y; }; struct XYline{ // Ax+By+C=0; double A; double B; double C; }; struct XYsegment{ XYpoint a,b; }; struct XYround{ // 圆 XYpoint center; double r; }; inline double min(double a,double b) { return ab?a:b; } inline double max(double a,double b) { return ab?a:b; } /********************************************/ /* 两点确定一条直线 */ /********************************************/ XYline makeLine(double x1,double y1,double x2,double y2) { XYline line; line.A=(y2-y1); line.B=(x1-x2); line.C=y1*(x2-x1)+x1*(y1-y2); return line; } /********************************************/ /* 两点间距离 */ /********************************************/ inline double dis_PP(double x1,double y1,double x2,double y2) { return sqrt( (x1-x2)*(x1-x2) + (y1-y2)*(y1-y2) ); } /********************************************/ /* 点直线距离 */ /********************************************/ double dis_PL(double x,double y,XYline line) { return fabs(line.A*x + line.B*y + line.C) / sqrt(line.A*line.A + line.B*line.B); } /********************************************/ /* 海伦公式求三角形面积 */ /********************************************/ double triangleArea(double x1,double y1,double x2,double y2,double x3,double y3) { double a=sqrt( (x1-x2)*(x1-x2) + (y1-y2)*(y1-y2) ); double b=sqrt( (x1-x3)*(x1-x3) + (y1-y3)*(y1-y3) ); double c=sqrt( (x3-x2)*(x3-x2) + (y3-y2)*(y3-y2) ); double s=(a+b+c)/2; return sqrt( s * (s-a) * (s-b) * (s-c) ); } inline double tArea(XYpoint p1,XYpoint p2,XYpoint p3) { return fabs(0.5*((p3.y-p1.y)*(p2.x-p1.x)-(p2.y-p1.y)*(p3.x-p1.x))); } /********************************************/ /* 判断直线相交 */ /* 1 - 有交点 0 - 无交点 -1 - 重合 */ /********************************************/ int inter

文档评论(0)

asd522513656 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档