poj 1673(EXOCENTER OF A TRIANGLE) (垂心证明)
poj 1673(EXOCENTER OF A TRIANGLE) (垂心证明)
http://poj.org/problem?id=1673
//180k 0ms //实质上就是求三角形的垂心
#include<iostream>
#define eps 1e-8
using namespace std;
struct Point
{
double x,y;
};
Point symmetric_point(Point p1, Point l1, Point l2) //求一点关于直线的对称点
{
Point ret;
if(l1.x>l2.x-eps&&l1.x<l2.x+eps)
{
ret.x=(2*l1.x-p1.x);
ret.y = p1.y;
}
else if(l1.y>l2.y-eps&&l1.y<l2.y+eps)
{
ret.x=p1.x;
ret.y=2*l1.y-p1.y;
}
else
{
double k = (l1.y - l2.y ) / (l1.x - l2.x);
ret.x = (2*k*k*l1.x + 2*k*p1.y - 2*k*l1.y - k*k*p1.x + p1.x) / (1 + k*k);
ret.y = p1.y - (ret.x - p1.x ) / k;
}
return ret;
}
Point Intersection(Point u1,Point u2,Point v1,Point v2)
{
Point ret=u1;
double t=((u1.x-v1.x)*(v1.y-v2.y)-(u1.y-v1.y)*(v1.x-v2.x))/((u1.x-u2.x)*(v1.y-v2.y)-(u1.y-u2.y)*(v1.x-v2.x));
ret.x+=(u2.x-u1.x)*t;
ret.y+=(u2.y-u1.y)*t;
return ret;
}
int main()
{
int n;
Point a,b,c,temp1,temp2;
while(scanf("%d",&n)!=EOF)
{
while(n--)
{
scanf("%lf%lf%lf%lf%lf%lf",&a.x,&a.y,&b.x,&b.y,&c.x,&c.y);
temp1=symmetric_point(a,b,c); //求出a关于直线b,c的对称点 temp1
temp2=symmetric_point(b,a,c); // 求出b关于直线a,c的对称点 temp2
c=Intersection(a,temp1,b,temp2); //求出a,temp1,btemp2的交点
printf("%.4lf %.4lf\n",c.x,c.y);
}
}
return 0;
}
poj 1673(EXOCENTER OF A TRIANGLE) (垂心证明)相关推荐
- POJ 1673 EXOCENTER OF A TRIANGLE(证明+求三角形垂心)
POJ 1673 EXOCENTER OF A TRIANGLE(证明+求三角形垂心) http://poj.org/problem?id=1673 题意: ZOJ 1821 有一个三角形ABC,扩展 ...
- POJ 1673 EXOCENTER OF A TRIANGLE(求三角形的垂心)
博客原文地址:http://blog.csdn.net/xuechelingxiao/article/details/40654421 EXOCENTER OF A TRIANGLE 题目大意:一个三 ...
- POJ 1673 EXOCENTER OF A TRIANGLE(解三角形重心)
题目链接:http://poj.org/problem?id=1673 AC代码: #include<cstdio> #include<cmath> #include<a ...
- POJ 1673 EXOCENTER OF A TRIANGLE
这道题就是求点的时候麻烦了点,思路还是很简单的 刚开始把向量反向写成了swap(x,y),其实应该是x=-x,y=-y #include<stdio.h> #include<math ...
- poj pku 1673 EXOCENTER OF A TRIANGLE 三角形 垂心
[b][color=blue]题目描述:[/color][/b][url]http://poj.org/problem?id=1673[/url][size=large][/size] 该题重点是求证 ...
- pku 1673 EXOCENTER OF A TRIANGLE
http://acm.pku.edu.cn/JudgeOnline/problem?id=1673 题意归结到最后就是求三角形的锤心.由三角形的锤心公式可求得: 垂心: A(x1,y1)B(x2,y2 ...
- POJ1673 EXOCENTER OF A TRIANGLE(三角形垂心)
题目链接: http://poj.org/problem?id=1673 题目描述: EXOCENTER OF A TRIANGLE Description Given a triangle ABC, ...
- poj1673 EXOCENTER OF A TRIANGLE
地址:http://poj.org/problem?id=1673 题目: EXOCENTER OF A TRIANGLE Time Limit: 1000MS Memory Limit: 100 ...
- POJ 计算几何入门题目推荐
其实也谈不上推荐,只是自己做过的题目而已,甚至有的题目尚未AC,让在挣扎中.之所以推荐计算几何题,是因为,本人感觉ACM各种算法中计算几何算是比较实际的算法,在很多领域有着重要的用途(例如本人的专 ...
- [Z]POJ 计算几何入门题目推荐[转PKKJ]
http://www.cnblogs.com/eric-blog/archive/2011/05/31/2064785.html http://hi.baidu.com/novosbirsk/blog ...
最新文章
- 34 个火爆全网的Python开源框架
- 安波副教授:分布式人工智能进展与趋势
- 机器“血液”登上Nature:一条假鱼靠它续航36小时,无需固态电池
- 简单三步,用 Python 发邮件
- Clojure开发OpenCV的简介
- 【2018.4.14】模拟赛之四-ssl2394 剪草【dp】
- 【渝粤教育】国家开放大学2018年秋季 1133t文献检索 参考试题
- m.2接口和nvme区别_M.2接口硬盘当真速度就快吗?这些不懂就别乱买!今天再说一遍...
- WebAPI框架里设置异常返回格式统一
- ACR2010_常规医疗环境下TNF拮抗剂对RA骨侵蚀的修复作用
- ERP计划参数如何在线更新
- hbase倒序查询_hbase过滤器汇总【查询汇总】
- LINUX下载及编译libtool
- [转]UBB代码解析规范
- Android应用程序开发以及背后的设计思想深度剖析
- 酒店的月收入报表java_统计报表_宾馆明细收入报表
- 权重股启动意味着什么
- 【PP那些事儿】生产模式-面向订单生产
- wex5 mysql root密码_WeX5基础
- YY直播黑盒测试工程师笔试题
热门文章
- 磁盘一把锁一个感叹号_Win10系统中如何解决磁盘图标上出现感叹号的情况
- 64位CPU,64位操作系统,和64位应用程序三者之间的关系
- 一个优质软件测试工程师简历,疯狂面试5家公司......
- 双边功率谱密度和单边功率谱密度_以高斯信号为例,计算幅度谱、相位谱、双边功率谱、双边功率谱密度、单边功率谱、单边功率谱密度。...
- 计算机毕设(附源码)JAVA-SSM基于java学科竞赛管理系统
- 2015年至2017年的国产电影圈的数据分析
- 在树莓派计算模块CM4 eMMC上安装Ubuntu Server 21.10
- 液晶拼接大屏的日常维护与保养
- python背单词小程序_微信小程序仿《乐词》背单词APP源码
- Ansible-template模块使用(jinjia2模板)