poj 1375 Intervals(解析几何 过圆外一点求与圆的切线)
来源:互联网 发布:行知职高宿舍样子 编辑:程序博客网 时间:2024/05/04 05:46
题目大意:给出一个光源,给出一些圆,求投影区间。
如图,先可以求出角a,通过半径与PQ距离,而角b也可以求出。那么就可以求出两条切线与Y轴的夹角,分别为a+b,b-a。
之后利用角度求出各投影线段的左右顶点,排序判断即可。
#include<iostream>#include<algorithm>#include<cmath>#include<cstdio>using namespace std;struct Point{ double x,y;}p,q;struct Node{ double l,r;}line[505];double dist(Point p1,Point p2){ return sqrt((p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y));}bool cmp(Node n1,Node n2){ return n1.l<n2.l;}int main(){ int n; double r; while(scanf("%d",&n)!=EOF&&n) { scanf("%lf%lf",&p.x,&p.y); for(int i=0;i<n;i++) { scanf("%lf%lf%lf",&q.x,&q.y,&r); double d=dist(p,q); double a=asin(r/d),b=asin((p.x-q.x)/d); double ang1=a+b,ang2=b-a; line[i].l=p.x-p.y*tan(ang1); line[i].r=p.x-p.y*tan(ang2); } sort(line,line+n,cmp); double L=line[0].l,R=line[0].r; for(int i=1;i<n;i++) { if(line[i].l>R) { printf("%.2f %.2f\n",L,R); L=line[i].l;R=line[i].r; } else R=max(line[i].r,R); } printf("%.2f %.2f\n\n",L,R); } return 0;}
0 0
- poj 1375 Intervals(解析几何 过圆外一点求与圆的切线)
- POJ 1375 Intervals 解析几何 求圆的切线
- POJ 1375 Intervals【过定点做圆的切线】
- POJ 1375 过一点求圆切线极角
- 过圆外一点与圆的切线方程()
- poj 1375 Intervals 圆的切线
- poj 1375 Intervals(计算圆的切线)
- POJ 1375 Intervals(解析几何)
- POJ 1375 求圆外一点引圆的切线
- [matlab]过一点与椭圆的切线
- POJ1375 Intervals(解析几何,圆)
- POJ 1375 圆外一点引向圆的切线,直线交点
- POJ 1375 圆切线
- poj 1375 Intervals(圆外一点到圆的切点)
- 第11周项目4-3求过圆外一点与圆心的连线与圆的两个交点
- Flash 与数学:圆的切线(2)
- Flash 与数学:圆的切线(3)
- Flash 与数学:圆的切线(4)
- iOS UI 基础篇:button、textFiled、timer、alert
- 多线程
- CentOS 关闭启用selinux
- HDU 4652 Dice(概率dp)
- 黑马程序员——异常
- poj 1375 Intervals(解析几何 过圆外一点求与圆的切线)
- bellman-ford算法
- python如何使用 os.path.exists()--Learning from stackoverflow
- 【连载】Java学习系列(002)——数据类型和常用运算
- IOS 多线程创建的三种方法介绍(一)NSThread
- BCB编写dll
- oc的第五天
- sdut-2159 Ivan comes again!(set+线段树)
- 第三章第16题