Tornado

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 196    Accepted Submission(s): 48

Problem Description
Professor Jonathan is a well-known Canadian physicist and meteorologist. People who know him well call him “Wind Chaser”. It is not only because of his outstanding tornado research which is the most influential in the academic community, but also because of his courageous act in collecting real data of tornados. Actually he has been leading his team chasing tornado by cars equipped with advanced instruments hundreds of times.

In summer, tornado often occurs in the place where Professor Jonathan lives. After several years of research, Wind Chaser found many formation rules and moving patterns of tornados. In the satellite image, a tornado is a circle with radius of several meters to several kilometers. And its center moves between two locations in a straight line, back and forth at a fixed speed. After observing a tornado’s movement, Wind Chaser will pick a highway, which is also a straight line, and chase the tornado along the highway at the maximum speed of his car.

The smallest distance between the Wind Chaser and the center of the tornado during the whole wind chasing process, is called “observation distance”. Observation distance is critical for the research activity. If it is too short, Wind Chaser may get killed; and if it is too far, Wind Chaser can’t observe the tornado well. After many times of risk on lives and upset miss, Wind Chaser turns to you, one of his most brilliant students, for help. The only thing he wants to know is the forthcoming wind chasing will be dangerous, successful or just a miss.

 
Input
Input contains multiple test cases. Each test case consists of three lines which are in the following format.

xw1 yw1 xw2 yw2 vw
xt1 yt1 xt2 yt2 vt
dl du

In the first line, (xw1, yw1) means the start position of Wind Chaser; (xw2, yw2) is another position in the highway which Wind Chaser will definitely pass through; and vw is the speed of the car. Wind chaser will drive to the end of the world along that infinite long highway.
In the second line, (xt1, yt1) is the start position of tornado; (xt2, yt2) is the turn-around position and vt is the tornado’s speed. In other words, the tornado’s center moves back and forth between (xt1, yt1) and (xt2, yt2) at speed vt .

The third line shows that if the observation distance is smaller than dl , it will be very dangerous; and if the observation distance is larger than du, it will be a miss; otherwise it will lead to a perfect observation.

All numbers in the input are floating numbers.

-2000000000 <= xw1, yw1, xw2, yw2, xt1, yt1, xt2, yt2 <= 2000000000
1 <= vw, vt <= 20000
0 <= dl, du <= 2000000

Note:
1.  It’s guaranteed that the observation distance won’t be very close to dl or du during the whole wind chasing process. There will be at least 10-5 of difference. 
2.  Wind Chaser and the tornado start to move at the same time from their start position.

 
Output
For each test case output one line contains one word “Dangerous”, “Perfect” or “Miss” which describes the prediction of the observation.
 
Sample Input
0 0 1 0 2
10 -5 12 7 4
1.3 2.7
0 0 1 0 2
10 -5 12 7 1
0.3 0.4
 
Sample Output
Dangerous
Perfect
 
Source
 
Recommend
gaojie   |   We have carefully selected several similar problems for you:  2490 2494 3254 2267 1755 
 

代码:

 #include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
const int MAX= ;
const double esp = 1e-; struct Tnode
{
double x,y;
}w1,w2,t1,t2;
double vw,vt,dl,du;
double getmin(double a , double b)
{
return (a>b)?b:a;
}
//求点积
double dianji(Tnode &a ,Tnode &b ,Tnode &c)
{
return (b.x-a.x)*(c.x-a.x)+(b.y-a.y)*(c.y-a.y);
}
//求叉 积
double det(Tnode &a ,Tnode &b ,Tnode &c)
{
return (b.x-a.x)*(c.y-a.y)-(c.x-a.x)*(b.y-a.y);
}
//求距离
double dis(Tnode &a,Tnode &b)
{
return sqrt(fabs((b.x-a.x)*(b.x-a.x)+(b.y-a.y)*(b.y-a.y)));
}
//求点o到线段的最近的距离
double getdistance(Tnode &o,Tnode a ,Tnode b,double dx,double dy)
{
a.x+=dx;
a.y+=dy;
b.x+=dx;
b.y+=dy;
double d =getmin(dis(o,a),dis(o,b));
double di=dis(a,b);
if(di<=esp) return dis(o,a);
if(dianji(a,o,b)>=-esp&&dianji(b,o,a)>=-esp)
return fabs(det(a,b,o))/di;
else
return getmin(dis(o,a),dis(o,b));
}
//求o到以线段ab为起始,(dx,dy)为间距的平行线段的最近距离
double calc(Tnode &o ,Tnode &a ,Tnode &b , double dx, double dy)
{
Tnode a1,b1;
int ll=,rr=MAX;
while(ll<rr)
{
int mid=(ll+rr)/;
double d1=getdistance(o,a,b,dx*mid,dy*mid);
double d2=getdistance(o,a,b,dx*(mid+),dy*(mid+));
if(d1<=d2+esp) rr=mid;
else ll=mid+;
}
return getdistance(o,a,b,dx*ll,dy*ll);
}
void work()
{
Tnode wdr ,tdr,move,a1,b1,a2,b2;
double distance,time,d,d1,d2;
distance=dis(w1,w2);
wdr.x = (w2.x-w1.x)*vw/distance;
wdr.y = (w2.y-w1.y)*vw/distance;
distance = dis(t1,t2);
time = distance/vt;
tdr.x = (t2.x-t1.x)*vt/distance;
tdr.y=(t2.y-t1.y)*vt/distance;
move.x=(-wdr.x+tdr.x)*time;
move.y=(-wdr.y+tdr.y)*time;
//求两个线段簇的第一条线段a1-b1和a2-b2
a1=t1;
b1.x=a1.x+move.x;
b1.y=a1.y+move.y;
move.x=(-wdr.x-tdr.x)*time;
move.y=(-wdr.y-tdr.y)*time;
a2=b1;
b2.x=a2.x+move.x;
b2.y=a2.y+move.y;
//分别求点w1到两个线段簇的最近距离d1和d3
d1=calc(w1,a1,b1,b2.x-a1.x,b2.y-a1.y);
d2=calc(w1,a2,b2,b2.x-a1.x,b2.y-a1.y);
//判断结果
d=getmin(d1,d2);
if(d+esp<d1) printf("Dangerous\n");
else if(d-esp>du) printf("Miss\n");
else printf("Perfect\n");
}
int main()
{
while(scanf("%lf",&w1.x)!=EOF)
{
scanf("%lf%lf%lf%lf",&w1.y,&w2.x,&w2.y,&vw);
scanf("%lf%lf%lf%lf%lf",&t1.x,&t1.y,&t2.x,&t2.y,&vt);
scanf("%lf%lf",&dl,&du);
work();
}
return ;
}

hdu------2488Tornado(几何)的更多相关文章

  1. hdu 5430(几何)

    题意:求光在圆内反射n次后第一次返回原点的方案数 如果k和n-1可约分,则表明是循环多次反射方案才返回原点. #include <iostream> #include <cstrin ...

  2. hdu 1577 WisKey的眼神 (数学几何)

    WisKey的眼神 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  3. POJ 3831 &amp; HDU 3264 Open-air shopping malls(几何)

    题目链接: POJ:id=3831" target="_blank">http://poj.org/problem?id=3831 HDU:http://acm.h ...

  4. HDU 1700 Points on Cycle (几何 向量旋转)

    http://acm.hdu.edu.cn/showproblem.php?pid=1700 题目大意: 二维平面,一个圆的圆心在原点上.给定圆上的一点A,求另外两点B,C,B.C在圆上,并且三角形A ...

  5. HDU 1432 Lining Up(几何)

    http://acm.hdu.edu.cn/showproblem.php?pid=1432 题目大意: 2维平面上给定n个点,求一条直线能够穿过点数最多是多少. 解题思路: 因为题目给定的n(1~7 ...

  6. HDU 1392 Surround the Trees(几何 凸包模板)

    http://acm.hdu.edu.cn/showproblem.php?pid=1392 题目大意: 二维平面给定n个点,用一条最短的绳子将所有的点都围在里面,求绳子的长度. 解题思路: 凸包的模 ...

  7. hdu 5839(三维几何)

    Special Tetrahedron Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Othe ...

  8. hdu 1115 Lifting the Stone (数学几何)

    Lifting the Stone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  9. hdu 1086 You can Solve a Geometry Problem too (几何)

    You can Solve a Geometry Problem too Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/3 ...

  10. HDU 5128.The E-pang Palace-计算几何

    The E-pang Palace Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 512000/512000 K (Java/Othe ...

随机推荐

  1. pivot 与 unpivot 函数是SQL05新提供的2个函数 灰常灰常的实用

    转自:http://blog.sina.com.cn/s/blog_5ef755720100cyo3.html pivot函数: create table test(id int,name varch ...

  2. Oracle重置过期的密码

    过期的原因一般有两种可能: 一.由于Oracle 11g在默认的default概要文件中设置了“PASSWORD_LIFE_TIME=180”天导致:   这种情况的解决办法: 1.查看用户的proi ...

  3. Java编程思想读书笔记

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  4. Java——Java日期转Sql日期

    import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; public cl ...

  5. C#生成JSON数据

    protected void Page_Load(object sender, EventArgs e) { Response.Clear(); Response.ContentType = &quo ...

  6. 基于Spark ALS构建商品推荐引擎

    基于Spark ALS构建商品推荐引擎   一般来讲,推荐引擎试图对用户与某类物品之间的联系建模,其想法是预测人们可能喜好的物品并通过探索物品之间的联系来辅助这个过程,让用户能更快速.更准确的获得所需 ...

  7. Doragon Kuesuto 1.15

    #include<stdio.h> #include<stdlib.h> #include<time.h> int main() { ; ; ; int actio ...

  8. mysql 求时间段平均值

    考虑下面的需求,在一段时间内,间隔一段时间,取一个平均值,把所有的平均值取出来,怎么办?思路:在存储过程中,拼接sql语句.根据起始时间和结束时间,while循环每次加一段时间.DROP PROCED ...

  9. GFS Google File System(中文翻译)

    Google文件系统 GFS是一个可扩展的分布式文件系统,用于大型的.分布式的.对大量数据进行访问的应用.它运行于廉价的普通硬件上,但可以提供容错功能.它可以给大量的用户提供总体性能较高的服务. 1. ...

  10. 查看package编译时的错误信息及重新编译

    开发时,一般都是使用PL/SQL工具进行开发,查看编译错误及重新编译都很简单,但是一般的生产环境是不允许连接外界工具的,只能在命令行中进行重新编译及查看,今天我就遇到了这个问题,现在总结如下: 1.获 ...