#P642. 航海探险

航海探险

题目描述

在大海中,有 nn 座不确定坐标的岛屿。接下来,会陆续发现这些岛屿之间的相对位置关系,在发现的过程中,系统也会询问一些岛屿之间的距离:

  • 若有两岛屿的相对位置关系被发现了,则输入格式为 D a b e,表示岛屿 aa 在岛屿 bbD 方向 ee 公里。D 必须是 ESWN 中的一个字母,分别表示东南西北四个方向,输入数据保证不会有矛盾的情况发生,但有些信息可能是重复多余的。
  • 如果输入格式为 ? a b,表示需要查询岛屿 aa 在岛屿 bb 之间的距离。如果 aabb 之间的相对关系尚不确定,则输出 ?

注意,在计算距离时,所使用的定义是横纵坐标的差的绝对值之和,这种距离定义被称为城市距离或曼哈顿距离,而非常用的欧几里得距离。

输入格式

  • 第一行:两个整数 nnmm
  • 接下来 mm 行:每行首先有一个字母代表操作的类型,接下来有两个整数表示操作涉及的两座岛屿编号 aabb
    • 如果字母是 ‘?’,表示一条查询,输出 aabb 之间的距离,若它们之间的距离尚不能确定,则输出 ?
    • 如果字母是 ‘ESWN’ 中的一个,表示这是一条提供岛屿之间相对位置的消息,这一行除 aabb 外,最后还有一个正整数 ee,表示在 aa 的指定方向上与 bb 相隔 ee 个单位。

输出格式

若干行:对于每个询问,如果相对位置已经确认了,输出它们之间的城市坐标的距离,否则输出一个 ‘?’。

5 7
E 1 5 9
? 1 5
S 5 4 3
? 2 3
N 2 1 6
N 1 3 4
? 2 5
9
?
15

数据范围

1n40,0001 \leq n \leq 40,000 1m100,0001 \leq m \leq 100,000 1a,bn1 \leq a,b \leq n 1e1091 \leq e \leq 10^9 DN,S,W,ED∈{'N','S','W','E'}