CF1932G.Moving Platforms
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
There is a game where you need to move through a labyrinth. The labyrinth consists of n platforms, connected by m passages.
Each platform is at some level li , an integer number from 0 to H−1 . In a single step, if you are currently on platform i , you can stay on it, or move to another platform j . To move to platform j they have to be connected by the passage, and their levels have to be the same, namely li=lj .
After each step, the levels of all platforms change. The new level of platform i is calculated as li′=(li+si)modH , for all i .
You start on platform 1 . Find the minimum number of steps you need to get to platform n .
输入格式
The first line of input contains a single integer t ( 1≤t≤104 ) — the number of test cases. Then the descriptions of the test cases follow.
The first line of each test case contains three integers n , m , and H ( 2≤n≤105 , 1≤m≤105 , 1≤H≤109 ).
The second line contains n integers li , the initial level of each platform ( 0≤li≤H−1 ).
The third line contains n integers si , the change of level for each platform ( 0≤si≤H−1 ).
Next m lines contain a description of the passages. Each passage is described as a pair of integers — the platforms, connected by the passage. There is at most one passage connecting each pair of platforms, and there is no passage connecting a platform to itself.
The sum of n for all tests does not exceed 105 , the sum of m for all tests does not exceed 105 .
输出格式
For each test case, print a single integer, the minimum number of steps needed to get from platform 1 to platform n .
If it is impossible to get to platform n , print −1 .
输入输出样例
输入#1
3 3 3 10 1 9 4 2 3 0 1 2 3 2 1 3 2 1 10 1 2 4 6 1 2 8 7 25 22 14 5 3 10 14 11 1 9 5 4 10 7 16 18 18 2 8 6 3 3 5 7 5 2 6 1 4 4 7
输出#1
6 -1 52
说明/提示
This is how levels of the platforms change, and what actions we need to perform in the first example.
Platform 1Platform 2Platform 3ActionStep 1194Stay on the platform 1Step 2324Stay on the platform 1Step 3554Move to the platform 2Step 4784Stay on the platform 2Step 5914Stay on the platform 2Step 6144Move to the platform 3