#CCC21S4. Daily Commute

Daily Commute

Toronto has N subway stations, numbered from 1 to N. You start at station 1, and every day, you need to reach station N to get to school.

There are W one-way walkways running amongst the stations, the ith^{th} of which allows you to walk from station Ai_i to a different station Bi_i (1≤Ai_i,Bi_i≤N,Ai_i≠Bi_i) in 1 minute. There may be multiple walkways connecting any given pair of stations.

The subway line follows a certain route through the N stations, starting at station 1 and visiting each station once. Initially, this route consists of stations S1_1,S2_2,…,SN_N, in that order. S1_1=1, and S2_2,…,SN_N is a permutation of the integers 2,…,N. Only one subway train runs along this route per day, departing from station 1 at 6am in the morning and taking 1 minute to reach each subsequent station. This means that, m minutes after 6am, the train will be at station Sm+1_{m+1} (or at station SN_N if m≥N−1).

Over a period of D days, however, the subway line's route will keep changing. At the start of the ith^{th} day,the Xi_ith^{th} station and Yi_ith^{th} station (2≤Xi_i,Yi_i≤N,Xi_i≠Yi_i) in the route will be swapped. Note that, after each such change, the route will still begin at station 1 and will visit all N stations once each. Changes will carry over to subsequent days – the route will not automatically reset itself back to S1_1,…,SN_N.

On each of these D days, you'd like to determine how quickly you can get to school so you can begin learning things. On the ith^{th} day, starting at 6am in the morning (after the ith^{th} update to the subway line's route), you'll begin your daily trip to station N. Each minute, you may either ride the subway to its next stop (if you're currently at the same station as the train and it hasn't already completed its route), take a walkway from your current station to another one, or wait at your current station. Note that your trip begins at the same time as the train's route, meaning that you may choose to immediately ride it if you'd like to, and that you may choose to leave and then get back on the train during your trip.

Input Specification

The first line contains three space-separated integers, N, W, and D. The next W lines each contain two space-separated integers, Ai_i and Bi_i (1≤i≤W). The next line contains the N space-separated integers, S1_1,…,SN_N, which form the initial permutation of stations. The next D lines each contain two space-separated integers, Xi_i and Yi_i (1≤i≤D).

The following table shows how the available 15 marks are distributed.

Subtask N W D
2 marks 3≤N≤10 0≤W≤10 1≤D≤10
3≤N≤200 0≤W≤200 1≤D≤200
3 marks 3≤N≤2000 0≤W≤2000 1≤D≤2000
8 marks 3≤N≤200000 0≤W≤200000 1≤D≤200000

Output Specification

The output is D lines, with one integer per line. The ith line is the minimum number of minutes required to reach station N on the ith^{th} day (1≤i≤D).

Sample Input

4 3 3
1 2
3 4
4 1
1 4 3 2
3 4
4 2
3 2

Output for Sample Input

1
2
3

Explanation of Output for Sample Input

At the start of the first day, the subway line's route will be updated to visit stations [1,4,2,3], in that order. On that day, you should simply take the subway to station 4, taking 1 minute.

On the second day, the route will become [1,3,2,4], and you should take the subway to station 3 (taking 1 minute) and then walk to station 4 (taking 1 more minute).

On the third day, the route will become [1,2,3,4]. One choice of optimal trip involves walking to station 2 (taking 1 minute), then boarding the train there and taking it through station 3 and finally to station 4 (taking another 2 minutes).