假设你现在要为带有雷达的导弹拦截系统写一个判断程序,需要判断是否发射导弹拦截或者目标还有多久进入拦截区。
导弹发射井中一次填装有三枚导弹,每一枚导弹拦截半径为200km,拦截半径以内的范围即为拦截区,拦截区内的敌方目标均要拦截。
程序的输入数据是雷达传递过来的参数。
第一个参数N表示雷达捕获的目标数。
接下来传递N组参数。每组参数第一个数据判断敌友,要么为0表示敌方器械,要么为1表示己方器械。第二个数据表示雷达发射波段的原始频率f0,第三个数据表示雷达接收反射波的频率f1。f0、f1的单位都是吉赫兹(GHz),且在1~15之间,为了保证精度,小数点后保留八位。由相对论计算可知,f0、f1与目标的相对速度v(m/s)之间满足关系式f1=f0·(c+v)/(c-v),式中c表示光速,取c=299792458m/s,目标靠近雷达时v取正,反之取负。第四个数据是接收反射波与发射波之间的时间差,单位微秒(μs=10-6s)。
根据每组数据确定是否需要导弹出击拦截,导弹拦截最近的三个目标。若是暂时在拦截区外不需要出击拦截,则需计算出还有多长时间有目标进入拦截区(假设目标不改变航向、航速)或者是否朝向拦截区。
根据N组数据,对应输出对于每个目标的处理。共有五种情况:
拦截(YES)
不拦截:己方(NO:ONE OF US)
不拦截:下一次拦截(NO:NEXT TIME)
不拦截:(进入拦截区时间,单位秒(保留4位小数))
不拦截:远离(NO:AWAY)
7 1 3.00000000 3.00001401 1334 0 3.00000000 3.00001402 1200 0 3.00000000 2.99998997 1321 0 2.99998997 3.00000000 1200 0 2.99998997 3.00000000 1225 0 3.00000000 3.00001103 1400 0 2.99998997 3.00000000 1250
Target1:NO:ONE OF US Target2:YES Target3:NO:AWAY Target4:YES Target5:YES Target6:NO:17.8813 Target7:NO:NEXT TIME