Codeforces Round #416 (Div. 2) has been moved to start on 27.05.2017 09:05 (UTC).
×

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

E. Timofey and our friends animals

time limit per test

7 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputAfter his birthday party, Timofey went to his favorite tree alley in a park. He wants to feed there his favorite birds — crows.

It's widely known that each tree is occupied by a single crow family. The trees in the alley form a row and are numbered from 1 to *n*. Some families are friends to each other. For some reasons, two families can be friends only if they live not too far from each other, more precisely, there is no more than *k* - 1 trees between any pair of friend families. Formally, the family on the *u*-th tree and the family on the *v*-th tree can be friends only if |*u* - *v*| ≤ *k* holds.

One of the friendship features is that if some family learns that Timofey is feeding crows somewhere, it notifies about this all friend families. Thus, after Timofey starts to feed crows under some tree, all the families that are friends to the family living on this tree, as well as their friends and so on, fly to the feeding place. Of course, the family living on the tree also comes to the feeding place.

Today Timofey came to the alley and noticed that all the families that live on trees with numbers strictly less than *l* or strictly greater than *r* have flown away. Thus, it is not possible to pass the information about feeding through them. Moreover, there is no need to feed them. Help Timofey to learn what is the minimum number of trees under which he has to feed crows so that all the families that have remained will get the information about feeding. You are given several situations, described by integers *l* and *r*, you need to calculate the answer for all of them.

Input

The first line contains integers *n* and *k* (1 ≤ *n* ≤ 10^{5}, 1 ≤ *k* ≤ 5), where *n* is the number of trees, and *k* is the maximum possible distance between friend families.

The next line contains single integer *m* (0 ≤ *m* ≤ *n*·*k*) — the number of pair of friend families.

Each of the next *m* lines contains two integers *u* and *v* (1 ≤ *u*, *v* ≤ 10^{5}), that means that the families on trees *u* and *v* are friends. It is guaranteed that *u* ≠ *v* and |*u* - *v*| ≤ *k*. All the given pairs are distinct.

The next line contains single integer *q* (1 ≤ *q* ≤ 10^{5}) — the number of situations you need to calculate the answer in.

Each of the next *q* lines contains two integers *l* and *r* (1 ≤ *l* ≤ *r* ≤ 10^{5}), that means that in this situation families that have flown away lived on such trees *x*, so that either *x* < *l* or *x* > *r*.

Output

Print *q* lines. Line *i* should contain single integer — the answer in the *i*-th situation.

Example

Input

5 3

3

1 3

2 3

4 5

5

1 1

1 2

2 3

1 3

1 5

Output

1

2

1

1

2

Note

In the first example the following family pairs are friends: (1, 3), (2, 3) and (4, 5).

- In the first situation only the first family has remained, so the answer is 1.
- In the second situation the first two families have remained, and they aren't friends, so the answer is 2.
- In the third situation the families 2 and 3 are friends, so it is enough to feed any of them, the answer is 1.
- In the fourth situation we can feed the first family, then the third family will get the information from the first family, and the second family will get the information from the third. The answer is 1.
- In the fifth situation we can feed the first and the fifth families, so the answer is 2.

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: May/26/2017 02:44:06 (p1).

Desktop version, switch to mobile version.
User lists

Name |
---|