第32811题 程序题
三维城堡最短路径求解(含传送门、楼层传送器)

很久很久以前,巨龙突然出现,带来灾难带走了公主又消失不见。 公主米娅莫拉苏娜丹妮谢莉红被巨龙昆图库塔卡提考特苏瓦西拉松所困。 陛下希望你能把她救出并带回蒙达鲁克硫斯伯古比奇巴勒城。 你作为达拉崩巴斑得贝迪卜多比鲁翁接受了命令,骑上了最快的马,驰骋在路上。

已知巨龙的城堡是个三维形状,有k层,每层为n×m(n行m列)。 城堡内的构造为:

  • S为城堡的入口,起始你站在这个位置。
  • E为公主所在的位置,你需要到达此处,以救出公主。
  • .为可以自由活动的区域,你可以在这里进行同层的上下左右移动,移动一个单元花费1秒。
  • #为巨龙设置的陷阱,你不能进入这个区域。
  • @为楼层传送器,当你在第N层时,你可以在这里进行传送至N+1层或N-1层的相同坐标位置,传送花费2秒。
  • A ~ Z为传送门,除了SE最多有24种类型的传送门,每种传送门可能有多个并遍布整个城堡,你可以在同类型传送门中自由穿梭,不花费任何时间。

为救出公主,你需要计算最快到达公主的位置所要花费的时间。

输入描述

第一行输入3个正整数,k,n,m。 接着输入k个楼层,大小为n行m列。 每两个楼层之间空一行。

输出描述

输出1个整数,表示最快到达公主的位置所要花费的时间; 若无法到达,输出−1。

输入样例1

3 5 5
S..A#
..@..
@..B.
...@.
#####

.....
..@..
.A...
...@.
.....

@..B.
.###.
.#E.A
.#A..
.....

输出样例1

4

输入样例2

2 5 5
S.@..
@....
.....
.....
.....

.....
#....
..E..
.....
.....

输出样例2

6

提示

对于20%的测试数据,k=1,0<n></n>

编辑模式
程序运行统计
暂无判题统计