一.求两直线交点

复制代码 代码如下:

class Point {

double x;

double y;

public Point() {

this.x = 0;

this.y = 0;

}

}

class Line {

Point a;

Point b;

public Line() {

this.a = new Point();

this.b = new Point();

}

//求两直线的交点,斜率相同的话res=u.a

Point intersection(Line u,Line v){

Point res = u.a;

double t = ((u.a.x-v.a.x)*(v.b.y-v.a.y)-(u.a.y-v.a.y)*(v.b.x-v.a.x))

/((u.a.x-u.b.x)*(v.b.y-v.a.y)-(u.a.y-u.b.y)*(v.b.x-v.a.x));

res.x += (u.b.x-u.a.x)*t;

res.y += (uPeqKbk.b.y-u.a.y)*t;

return res;

}

二.求三角形外心1. 垂心: 三角形三条边上的高相交于一点.这一点叫做三角形的垂心.

2. 重心: 三角形三条边上的中线交于一点.这一点叫做三角形的重心.

3. 外心: 三角形三边的中垂线交于一点.这一点为三角形外接圆的圆心.

4. 内心三角形三内角平分线交于一点.这一点为三角形内切圆的圆心.

已知圆的3点,先求出3边长,由海伦公式得出面积S=sqrt(p*(p-a)*(p-b)*(p-c)) p=(a+b+c)/2;由三角形面积公式S=1/2*a*b*sin(C)和正弦定理a/sin(A)=b/sin(B)=c/sin(C)=直径(根据相同弦长对应的圆周角相同可证正http://www.cppcns.com弦定理)可得直径=a*b*c/2/S。

求圆心坐标。利用:G是⊿ABC外心的充要条件是(向量GA+向量GB)向量AB= (向量GB+向量GC)向量BC=(向量GC+向量GA)向量CA=向量0.

这个性质的证明很容易的,只需要想到外心是中垂线交点即可,就可以证明这个性质了,利用向量可以避免求斜率,以及考虑斜率不存在等很多情况。

复制代码 代码如下:

//三角形外接圆圆心(外心)

Point center(Point a,Point b,Point c) {

//加上这个才没有编译器提示未初始化,因为new所以也写了构造方法

Line u = new Line(),v = new Line();

u.a.x=(a.x+b.x)/2;

u.a.y=(a.y+b.y)/2;

u.b.x=u.a.x+(u.a.y-a.y);

u.b.y=u.a.y-(u.a.x-a.x);

v.a.x=(a.x+c.x)/2;

v.a.y=(a.y+c.y)/2;

v.b.x=v.a.x+(v.a.y-a.y);

v.b.y=v.a.y-(v.a.x-a.x);

return intersection(u,v);

}

三.求三角形内心        由于内心到各边距离就是半径r,可以把三角形分成三部分,再根据海伦公式得到半径r=2*S/(a+b+c)。

内切圆心坐标(x,y): 三角形三个顶点的坐标:A(x1,y1),B(x2,y2),C(x3,y3)则圆心为x=(x1*BC+x2*CA+x3*AB)/(AB+BC+CA)、y=(y1*BC+y2*CA+y3*AB)/(

证明:设三角形ABC,AD为BC边上的角平分线,内心为O。

|BC|=a,|AC|=b,|AB|=c

aOA+bOB+cOC

=aOA+b(AB+OA)+c(AC+OA)

=(a+b+c)OA+b(DB-DA)+c(DC-DA)

设BC的方向向量e,则DB=e|DB|,DC=-e|DC|

又由角平分线定理,|DB|/|DC|=c/b,所以bDB+cDC=0

(a+b+c)OA+b(DB-DA)+c(DC-DA)= (a+b+c)OA- b DA- c DA =aOPeqKbkA+(b+c)OD

又因为OA、OD反向,用角平分线定理和合比定理:

b/CD=c/BD=(b+c)/(CD+BD)=(b+c)/a, b/CD=OA/OD,

所以OA/OD=(b+c)/a , 又因为OA、OD反向,

故aOA+bOB+cOC=aOA+(b+c)OD =0.

本文标题: JAVA求两直线交点和三角形内外心的方法

本文地址: http://www.cppcns.com/ruanjian/java/101527.html

java大数求三角形外心_JAVA求两直线交点和三角形内外心的方法相关推荐

  1. java 求两线交点_JAVA求两直线交点和三角形内外心的编程代码

    JAVA求两直线交点和三角形内外心的编程代码 一.求两直线交点 复制代码 代码如下: class Point { double x; double y; public Point() { this.x ...

  2. java求最大子串_Java获取两个字符串中最大相同子串的方法

    "abcwerthelloyuiodef" "cvhellobnm" 思路: 1,将短的那个子串按照长度递减的方式获取到. 2,将每获取到的子串去长串中判断是否 ...

  3. 分别已知两直线上的两点,求两直线交点

    分别已知两直线上的两点,求两直线交点 求两直线的交点是初中数学的简单问题了,在直角坐标系中直线有很多种表示方式.同时我们知道两点确定一条直线,已知两点坐标自然能求出直线坐标,已知两直线坐标自然能求出两 ...

  4. 根据倾斜矩形中心点,长宽和倾斜角度,计算顶点,计算两直线交点

    已知倾斜矩形中心点center,长w,宽h,倾斜角theta.顶点计算公式为: void getRectVertex(const cv::Point center,float theta,float ...

  5. CAD中如何快速找到两直线交点?

    CAD是在很多行业都是必备的绘图软件,那么CAD中如何快速找到两直线交点?在CAD制图过程中,想要找出两直线交点该如何操作呢? 1.首先打开CAD制图工具迅捷CAD编辑器专业版,标准版同样也可以进行操 ...

  6. python 计算两直线交点

    最近在做图像的透射变换,有一个关键问题就是找到原图像内四边形的四个顶点. 在处理过程中,经过霍夫直线检测后,即可得到四边形的四边.而边的表示形式为:[x1,y1,x2,y2],即以两点确定一条直线. ...

  7. 如何快速找出两直线交点?

    我们在CAD中经常会遇到各类的问题,如果想要让CAD中两条直线相交该怎么办呢?下面来教你解决的方法. 1.我们使用迅捷CAD编辑器,然后我们输入"EX",在弹出的多个命令中,选择第 ...

  8. 算法之美——求两直线交点(三维叉积)——求四边形面积(二维叉积)

    一般方程法: 直线的一般方程为F(x) = ax + by + c = 0.既然我们已经知道直线的两个点,假设为(x0,y0), (x1, y1),那么可以得到a = y0 – y1, b = x1 ...

  9. 求两直线交点程序 C

    const   double   EPS                 =   1e-5;           //   计算精度  const   int   CROSS             ...

  10. xoy面上两直线交点算法

    已知两条直线(每条直线由2个点确定)求两条直线的交点. 1. 解方程组 我们的目的是要求两条直线相交的交点 , 求交点这就是即在直线1又在直线2的点(x,y),就是2个直线方程组的解(点同时满足两个直 ...

最新文章

  1. elasticsearch的备份和恢复(转)
  2. 第8章3节《MonkeyRunner源码剖析》 5
  3. Extjs4 MVC 示例
  4. 如何配置Spring的XML文件及使用
  5. Mysql查询数据库状态及信息
  6. iOS 做一个圆形渐变圆环
  7. 表达式树练习实践:入门基础
  8. DNS高速缓存及DDNS
  9. 1002 C语言输入解决方案
  10. Apache2.4使用require指令进行访问控制--允许或限制IP访问/通过User-Agent禁止不友好网络爬虫...
  11. win10我的电脑在哪里找到
  12. 【优化算法】人工电场优化算法(AEFA)【含Matlab源码 1797期】
  13. SWAT模型中土壤水文分组的一些思考
  14. 软件测试好书推荐《自动化测试实践》30个项目测试案例分析
  15. NISP-电子邮件安全
  16. 使用Postman获取北京时间校准接口API(Json格式)
  17. 游戏开发之NGUI字体集制作
  18. 计算方法实验一、秦九韶算法
  19. iOS App跟小程序之间跳转
  20. 聚合支付-x-pay

热门文章

  1. 常见For 循环优化方式总结——提高效率小妙招
  2. vnc远程控制linux密码,如何使用VNC远程控制Linux(Centos)?
  3. 高效能人士的七个习惯(零)前言
  4. moment.js时间格式转换
  5. Map-Based Indoor Pedestrian Navigation Using an Auxiliary Particle Filter
  6. mac php连接mysql数据库_Mac下php连接mysql数据库失败解决办法
  7. 大数据安全国内外技术发展现状与趋势现状
  8. 小程序window对象的探索
  9. 咸鱼の软构实验感想(1)
  10. 比“虚幻4”还牛逼的游戏引擎 到底有多神奇?