5728 - 赶飞机

通过次数

0

提交次数

48

时间限制 : 1 秒
内存限制 : 256 MB

假设在机场要乘坐的飞机快起飞了,必须立刻赶到登机口。幸运的是,从现在的位置到登机口是一条直线,所以只需要一直跑就行了。不过,因为拿了很多行李,所以最多只能跑t秒,可以连续不停地跑t秒,也可以先跑一段时间再体息一会儿然后再接着跑,甚至可以一直走着一秒都不跑,但是不管怎样,跑步的总时间不能超过t秒。

假设现在位于数轴上0的位置,登机口位于X的位置,每秒能跑r个单位长度,而走路每秒只能走s个单位长度。机场里还有一些传送带,第i个传送带以固定的每秒wi个单位运行着,当站到上面时速度会加上wi(即如果是走路,则速度变为s+wi,如果是跑步,速度就变为r+wi)。现在的问题是:至少需要多长时间才能到达登机口?

输入

第1行1个整数test,表示测试数据的组数。

对于每组测试数据,第1行输入5个整数x、s、r、t和n。x、s、r、t的意义见问题描述,n表示机场里一共有多少个传送带。

以下n行,每行3个整数,Bi、Ei,和Wi,分别表示每个传送带的起始位置、结束位置和运行速度。保证任何两个传送带都没有重叠部分。

输出

对于每组数据,输出一行“Case #x:y”。其中,x是测试数据的编号,y是你到达登机口的最少时间,精确到小数点后9位,字符串严格匹配。

样例

输入

3
10 1 4 1 2
4 6 1
6 9 2
12 1 2 4 1
6 12 1
20 1 3 20 5
0 4 5
4 8 4 
8 12 3
12 16 2
16 20 1

输出

Case #1:4.000000000
Case #2:5.500000000
Case #3:3.538095238

提示

【数据规模】

对于100%的数据满足:1≤test≤4,1≤s<r≤100,1≤W_i≤100,0≤B_iE_i≤x,E_iB_i+1,1≤t≤106,1≤x≤106,1≤n≤1000。

来源

课课通