Alien invasion began, and scary man-eating aliens are
establishing their bases all over the country. You are only
safe on the places that are sufficiently far away from all
current alien bases. You need to quickly write a program to
help you determine where to move.
Input
The input contains at most instances, each of them
consisting of several lines. The first line of each instance
contains integers
(),
(),
() and () separated by spaces, giving the number
of towns in the country, the number of roads between them, the
number of bases that the aliens are going to build, and the
minimum safe distance from alien bases, respectively. The towns
are assigned numbers .
The following lines
describe the roads; each of them contains integers , () and
() separated by
spaces, where is the
length of the road between towns and . There is at most one direct
road between any two towns. All roads can be used in both
directions.
The following lines
describe the positions of alien bases; the -th of them contains the number
() of the town
where the aliens build their -th base.
The last instance is followed by a line containing four
zeros.
Output
The output for each input instance consists of lines. On -th line, write the number of towns
that are safe after the aliens build their -th base. The town is safe if its
distance from any of the towns is at least
.
Print one empty line after each instance.
Sample Input 1 |
Sample Output 1 |
7 6 3 3
1 2 1
1 3 1
2 5 1
3 6 1
1 4 1
4 7 2
2
1
4
1 0 1 1
1
0 0 0 0
|
2
1
0
0
|