资讯 小学 初中 高中 语言 会计职称 学历提升 法考 计算机考试 医护考试 建工考试 教育百科
栏目分类:
子分类:
返回
空麓网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
空麓网 > 计算机考试 > 面试经验 > 面试问答

zoj 1309 Intervals

面试问答 更新时间: 发布时间: 计算机考试归档 最新发布

zoj 1309 Intervals

#include<iostream>#include<fstream>#include<iomanip>#include<cstdio>#include<cstring>#include<algorithm>#include<cstdlib>#include<cmath>#include<set>#include<map>#include<queue>#include<stack>#include<string>#include<vector>#include<sstream>#include<ctime>#include<cassert>#define LL long long#define eps 1e-8#define inf 999999.0#define zero(a) abs(a)<eps#define N 20#define MOD 100000007#define pi acos(-1.0)using namespace std;struct Point{    double x,y;    Point(){}    Point(double tx,double ty){x=tx;y=ty;}}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 %.2fn",L,R);     L=line[i].l;R=line[i].r; } else     R=max(line[i].r,R);        }        printf("%.2f %.2fnn",L,R);    }    return 0;}
转载请注明:文章转载自 http://www.konglu.com/
本文地址:http://www.konglu.com/it/377256.html
免责声明:

我们致力于保护作者版权,注重分享,被刊用文章【zoj 1309 Intervals】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理,本文部分文字与图片资源来自于网络,转载此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们,情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!

我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2023 成都空麓科技有限公司

ICP备案号:蜀ICP备2023000828号-2