301854: CF350E. Wrong Floyd

Memory Limit:256 MB Time Limit:1 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Wrong Floyd

题意翻译

给定$n$个点,$m$条边以及$k$个标记点,要求进行$Floyd$时只以标记的点为中间点进行松弛操作(每条边边权为$1$)要求你造出一共$m$条边的数据来$hack$掉$Valera$的程序

题目描述

Valera conducts experiments with algorithms that search for shortest paths. He has recently studied the Floyd's algorithm, so it's time to work with it. Valera's already written the code that counts the shortest distance between any pair of vertexes in a non-directed connected graph from $ n $ vertexes and $ m $ edges, containing no loops and multiple edges. Besides, Valera's decided to mark part of the vertexes. He's marked exactly $ k $ vertexes $ a_{1},a_{2},...,a_{k} $ . Valera's code is given below. ``` ans[i][j] // the shortest distance for a pair of vertexes i,j a[i] // vertexes, marked by Valera for(i = 1; i <= n; i++) { for(j = 1; j <= n; j++) { if (i == j) ans[i][j] = 0; else ans[i][j] = INF; //INF is a very large number } } for(i = 1; i <= m; i++) { read a pair of vertexes u, v that have a non-directed edge between them; ans[v] = 1; ans[v] = 1; } for (i = 1; i <= k; i++) { v = a[i]; for(j = 1; j <= n; j++) for(r = 1; r <= n; r++) ans[j][r] = min(ans[j][r], ans[j][v] + ans[v][r]); } ``` Valera has seen that his code is wrong. Help the boy. Given the set of marked vertexes $ a_{1},a_{2},...,a_{k} $ , find such non-directed connected graph, consisting of $ n $ vertexes and $ m $ edges, for which Valera's code counts the wrong shortest distance for at least one pair of vertexes $ (i,j) $ . Valera is really keen to get a graph without any loops and multiple edges. If no such graph exists, print -1.

输入输出格式

输入格式


The first line of the input contains three integers $ n,m,k $ ( $ 3<=n<=300 $ , $ 2<=k<=n $ , ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF350E/5d1246889ad04671f4f532ebb3f380ef9ac31a26.png)) — the number of vertexes, the number of edges and the number of marked vertexes. The second line of the input contains $ k $ space-separated integers $ a_{1},a_{2},...\ a_{k} $ ( $ 1<=a_{i}<=n $ ) — the numbers of the marked vertexes. It is guaranteed that all numbers $ a_{i} $ are distinct.

输出格式


If the graph doesn't exist, print -1 on a single line. Otherwise, print $ m $ lines, each containing two integers $ u,v $ — the description of the edges of the graph Valera's been looking for.

输入输出样例

输入样例 #1

3 2 2
1 2

输出样例 #1

1 3
2 3

输入样例 #2

3 3 2
1 2

输出样例 #2

-1

Input

题意翻译

给定$n$个点,$m$条边以及$k$个标记点,要求进行$Floyd$时只以标记的点为中间点进行松弛操作(每条边边权为$1$)要求你造出一共$m$条边的数据来$hack$掉$Valera$的程序

加入题单

上一题 下一题 算法标签: