莫勒定理,证明如下:

请结合下图看代码:

#include <iostream>
#include <math.h>
#include <iomanip> using namespace std; #define pi acos(-1.0) double lawofcosine(double a, double b, double c)
{
return acos((a*a+b*b-c*c)/(2.0*a*b));
} double getangle(double x1, double y1, double x2, double y2)
{
return atan2(1.0*(y2-y1),1.0*(x2-x1));
} double getdis(double x1, double y1, double x2, double y2)
{
return sqrt((y1-y2)*(y1-y2)+(x1-x2)*(x1-x2));
} double solveequation_x(double x1, double y1, double x2, double y2, double k1, double k2)
{
return (y1-y2+k2*x2-k1*x1)/(k2-k1);
} typedef struct point
{
double x, y;
} p; int main()
{
p A, B, C, D, E, F;
int n;
cin>>n;
while(n--)
{
cin>>A.x>>A.y>>B.x>>B.y>>C.x>>C.y; double a,b,c; //cout << A.x << ' ' << A.y << ' ' << B.x << ' ' << B.y << ' ' << C.x << ' ' << C.y << endl; a = getdis(B.x,B.y,C.x,C.y);
b = getdis(C.x,C.y,A.x,A.y);
c = getdis(B.x,B.y,A.x,A.y); //cout << "dis" << ' ' << a << '!' << b << '!' << c << endl; double alpha = lawofcosine(b,c,a);
double beta = lawofcosine(a,c,b);
double gama = lawofcosine(a,b,c); //cout << "angle" << ' ' << alpha * 180 / pi << '@' << beta * 180 / pi << '@' << gama * 180 / pi<<endl; double theta1 = getangle(A.x,A.y,B.x,B.y);//k(AB)angle
double theta2 = getangle(B.x,B.y,C.x,C.y);//k(CB)angle
double theta3 = getangle(A.x,A.y,C.x,C.y);//k(AC)angle //cout << "theta" << ' ' << theta1 * 180 / pi << '#' << theta2 * 180 / pi<< '#' << theta3 * 180 / pi<< endl; double k1 = tan(theta2 + beta / 3.0);//k(BD)
double k2 = tan(theta3 + gama / 3.0);//k(CE)
double k3 = tan(theta3 + 2.0 * gama / 3.0);//k(CD)
double k4 = tan(theta1 + 2.0 * alpha / 3.0);//k(AE) //cout << "k" << '$' << k1 * 180 / pi << '$' << k2 * 180 / pi << '$' << k3 * 180 / pi << '$' << k4 * 180 / pi << endl; D.x = (k1 * B.x - k3 * C.x + C.y - B.y) / (k1 - k3);
D.y = D.x * k1 - k1 * B.x + B.y; E.x = (k2 * C.x - k4 * A.x + A.y - C.y) / (k2 - k4);
E.y = E.x * k2 - k2 * C.x + C.y; double x1, y1, x2, y2;
x2 = D.x, y2 = D.y, x1 = E.x, y1 = E.y; double alpha1 = atan2((y1-y2),(x1-x2));
double l = sqrt((y1-y2)*(y1-y2)+(x1-x2)*(x1-x2));
double x3=x2+l*cos(alpha1+pi/3);
double y3=y2+l*sin(alpha1+pi/3); F.x = x3, F.y = y3; cout << fixed << setprecision(7) << D.x << ' ' << D.y << ' ' << E.x << ' ' << E.y << ' ' << F.x << ' ' << F.y << endl;
}
}

变成解析几何就太麻烦了,可是欧氏几何又没有现成的关系

UVa11187的更多相关文章

随机推荐

  1. 微信 JS API 支付教程

    最近一个项目中用到了微信开发,之前没有做过支付相关的东西,算是拿这个来练练手,刚开始接触支付时候很懵逼,加上微信支付开发文档本来就讲得不清楚,我是彻底蒙圈了,参考了很多代码之后,算是有一点思路了. 用 ...

  2. Description Resource Path Location Type The superclass "javax.servlet.http.HttpServlet" was not foun

    一段时间没亲自建新项目玩乐,今天建立了一Maven project的时候发现了以下异常,Description Resource Path Location Type The superclass & ...

  3. Codeforces 552C Vanya and Scales(进制转换+思维)

    题目链接:http://codeforces.com/problemset/problem/552/C 题目大意:有101个砝码重量为w^0,w^1,....,w^100和一个重量为m的物体,问能否在 ...

  4. 不同意义的new和delete

    补充说明: new/delete是运算符而非函数,operator new/delete并非是new/delete的重载.事实上,我们无法自定义new/delete的行为: operator new/ ...

  5. pycharm、webstorm和idea激活码

    pycharm ---> http://blog.csdn.net/kevinelstri/article/details/57413791 idea ---> http://idea.l ...

  6. AngularJs(SPA)单页面SEO以及百度统计应用(上)

    只有两种人最具有吸引力,一种是无所不知的人,一种是一无所知的人 问:学生问追一个女孩总是追不上怎么办?回答:女孩不是追来的,是吸引来的,你追的过程是吸引女孩的过程,如果女孩没有看上你,再追都是没有用的 ...

  7. C语言:打印A-Z字母组合的菱形图案

    题目: +++++++++A+++++++++++++++++BCD+++++++++++++++EFGHI+++++++++++++JKLMNOP+++++++++++QRSTUVWXY++++++ ...

  8. Linux学习笔记——基于鸟哥的Linux私房菜

    Linux学习笔记--基于鸟哥的Linux私房菜 ***** ARM与嵌入式linux的入门建议 (1) 学习基本的裸机编程:ARM7或ARM9,理解硬件架构和控制原理 (这一步是绝对的根基) (2) ...

  9. Java 中byte 与 char 的相互转换 Java基础 但是很重要

    char转化为byte: public static byte[] charToByte(char c) {        byte[] b = new byte[2];        b[0] = ...

  10. mysql关联表插入-php环境中

    $insertsql=<<<EOTinsert into tb_manager values(null,'$name','$pwd','1');select @pid:=last_i ...