#P2365. 塔顶瞭望

塔顶瞭望

题目描述

Curimit 建造了座高塔,他们竖直建造,塔底全部位于一条直线上,从左到右分别编
号为1~N,相邻的两座塔之间相距 1 个长度单位。每座塔的高度不尽相同,分别记为H1,H2,...Hn。每座塔的顶端都安装有一个闪光灯。 
某天夜晚,Antonio 来到了 Curimit 的庄园。Curimit 很高兴,同时邀请 Antonio 登上他的一座高塔观光。同时他告诉 Antonio,如果他登上了编号为K 的塔,他将会为 Antonio 打开编号介于Sk,Ek之间的塔顶上的闪光灯。由于塔的瞭望方向都是相同的,因此必然有1<=Sk<=Ek<k
现在,Antonio 定义了几种他观察闪光灯的方法: 
1: 仰视:如果观察的闪光灯的高度高于观察者,则定义这一观察为“仰视”。仰角定
义为观察者与闪光灯的连线与水平线的夹角。 
2: 俯视:如果观察的闪光灯的高度高于观察者,则定义这一观察为“俯视”。俯角定
义为观察者与闪光灯的连线与水平线的夹角。 
3:Curimit 建造的塔的高度两两不同,因此不可能出现平视。 
由于塔的高度很高,因此 Antonio 的身高以及塔的直径都可以忽略不计。 
现在,Antonio想知道他登上某一座塔后,所能观察到闪光灯的最大仰角与最小俯角。
由于Curimit建造的塔很多,导致这种计算非常的繁重与无聊。因此,Antonio希望你帮他写一个程序来算出这些他感兴趣的数据。 
输入文件第一行一个整数N,表示塔的个数。
接下来一行个用空格隔开的正整数,分别表示H1,H2...Hn,两两不同。
接下来N行,每行两个用空格隔开的整数Sk,Ek表示 Curimit 为 Antonio 点亮的灯的
序号区间。满足S1=E1=0,1<=Sk<=Ek<k.
输出文件共两行。 
第一行N个用空格隔开的分数,分别表示 Antonio 站在 座塔上时看到的闪光灯的最大
仰角的正切值。分数使用 a/b 的形式表示,且必须是既约的。整数写成 a/1。如果 Antonio站在某一座塔上不可能进行仰视,输出 0/0. 
第二行表示N个最小俯角的正切值,输出格式同第一行。 
每一行的末尾不要出现多余的空格。 

6
1 4 3 5 2 6
0 0
1 1
1 2
1 3
1 4
1 1
0/0 0/0 1/1 0/0 3/1 0/0
0/0 3/1 1/1 1/2 1/4 1/1