Toposort

Accepts: 30
Submissions: 98
Time Limit: 10000/5000 MS (Java/Others)
Memory Limit: 131072/131072 K (Java/Others)
Problem Description

There is a directed acyclic graph with nn vertices and mm edges. You are allowed to delete exact kk edges in such way that the lexicographically minimal topological sort of the graph is minimum possible.

Input

There are multiple test cases. The first line of input contains an integer TT indicating the number of test cases. For each test case:

The first line contains three integers nn, mm and kk (1n100000,0km200000)(1 \le n \le 100000, 0 \le k \le m \le 200000) -- the number of vertices, the number of edges and the number of edges to delete.

For the next mm lines, each line contains two integers uiu_i and viv_i, which means there is a directed edge from uiu_i to viv_i (1ui,vin)(1 \le u_i, v_i \le n).

You can assume the graph is always a dag. The sum of values of nn in all test cases doesn't exceed 10610^6. The sum of values of mm in all test cases doesn't exceed 2×1062 \times 10^6.

Output

For each test case, output an integer S=(i=1nipi) mod (109+7)S = (\displaystyle\sum_{i=1}^{n}{i\cdot p_i}) \text{ mod } (10^9 + 7), where p1,p2,...,pnp_{1}, p_{2}, ..., p_{n} is the lexicographically minimal topological sort of the graph.

Sample Input
3
4 2 0
1 2
1 3
4 5 1
2 1
3 1
4 1
2 3
2 4
4 4 2
1 2
2 3
3 4
1 4
Sample Output
30
27
30