#BZOJ1928. Kthroad

Kthroad

题目描述

众所周知,在太阳系外围有一圈小行星带,而太阳系中离小行星带最近的Neptune往往面临着遭受小行星轰击的威胁。突然,某天Neptune上的天文台发现有一群小行星有k颗气势汹汹的袭来。作为Neptune的天文部长的小t想知道这些小行星分别要多久会撞到Neptune。你能够帮助他吗?
这些小行星的运行遵循以下一些规则:
1.     任意两颗小行星不会经过完全一样的路径,但有可能有绝大部分相同。
2.     对于某些小行星有可能受到其路径上的比较大的矮行星的引力作用,而围绕某个区域转圈。
3.     由于力的方向性,所以所有路径方向都是一定的。
4.     我们把空间中小行星可能经过的地方抽象成一个个点,并标号。共有N个点
5.     由于我们只关心其路径长度,所以并不给出这些点的具体坐标。
6.     两点间有可能有多条直接路径。任意两点间共有M条这样的路径。
7.     每课小行星在一个单位时间中会运动一个天文单位。且都会在当前的从起点到Neptune的最短路径上运行。
8.     每颗小行星对于我们来说都是一样的。
    请你编程求出所有小行星从起点(同一个起点)到达Neptune的所需花费的时间。
    

输入格式

第1行: 5个用空格隔开的整数:N、M、K、S、T,N个点M条边K个小行星, 起点的标号S,Neptune的标号T。
接下来M行每行3个大于0的整数,表示每条边的起点标号和终点标号以及这条边的长度。 
 

输出格式

共有K行每行一个整数,表示一颗小行星所要花费的时间。
 
6 6 2 1 6
1 2 1
2 4 1
4 5 1
5 6 1
2 3 1
3 5 1
4
4

数据范围与约定

数据约定N<= 10000, M <= 500000, K <= 100

对于所有数据在给定的数据范围内阶梯增长。