| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 2 초 | 1024 MB | 143 | 41 | 33 | 28.205% |
그래프 이론에서 두 그래프의 적(곱)연산은 여러 가지가 정의되어 있는데, 대표적으로는 데카르트적, 텐서적, 강적이 있다. 이들의 정의는 다음과 같다.
정점이 $N$개인 그래프 $A$의 정점을 $A_i$ $(1 \leq i \leq N),ドル 정점이 $M$개인 그래프 $B$의 정점을 $B_i$ $(1 \leq i \leq M)$라 하자. 이때, 두 그래프를 곱한 새로운 그래프 $G$는 $N\times M$개의 정점을 가진다. 각 정점에 다음과 같은 번호를 붙이자: $G_{11}, G_{12}, \cdots, G_{1M}, G_{21}, \cdots, G_{NM}$.
이때, 연산별로 간선은 다음과 같이 정의된다.
예를 들어, 아래 그림 1에서 왼쪽 두 그래프를 데카르트적 연산하면 오른쪽 그래프의 9개 정점과 파란색 실선으로 된 간선, 텐서적 연산하면 9개 정점과 빨간색 점선으로 된 간선을 얻는다.
[그림 1] 데카르트적, 텐서적, 강적을 그림으로 나타낸 예시.
이때, 두 그래프 $A$와 $B$가 주어지면 이 그래프에 대해 다음과 같은 쿼리 $Q$개에 대한 답을 출력하는 프로그램을 구현하시오.
1 p q: 그래프 $A$와 $B$의 데카르트적 $G$에 대해 두 정점 $G_{pq}$와 $G_{11}$ 사이의 최단경로의 길이를 출력하여라. 경로가 없다면 -1을 출력하여라.2 p q: 그래프 $A$와 $B$의 텐서적 $G$에 대해 두 정점 $G_{pq}$와 $G_{11}$ 사이의 최단경로의 길이를 출력하여라. 경로가 없다면 -1을 출력하여라.3 p q: 그래프 $A$와 $B$의 강적 $G$에 대해 두 정점 $G_{pq}$와 $G_{11}$ 사이의 최단경로의 길이를 출력하여라. 경로가 없다면 -1을 출력하여라.첫 번째 줄에 그래프 $A$의 정점의 개수 $N$과 간선의 개수 $X$가 공백으로 구분되어 주어진다.
두 번째 줄부터 $X$개의 줄 중 $i$번째 줄에 그래프 $A$의 $i$번째 간선이 잇는 두 정점의 번호 $u_i$와 $v_i$가 공백으로 구분되어 주어진다.
그다음 줄에 그래프 $B$의 정점의 개수 $M$과 간선의 개수 $Y$가 공백으로 구분되어 주어진다.
그다음 줄부터 $Y$개의 줄 중 $i$번째 줄에 그래프 $B$의 $i$번째 간선이 잇는 두 정점의 번호 $u'_i$와 $v'_i$가 공백으로 구분되어 주어진다.
그다음 줄에 쿼리의 개수 $Q$가 주어진다.
그다음 줄부터 $Q$개의 줄에 쿼리가 한 줄에 하나씩 주어진다. 쿼리의 형식은 지문을 참고하여라.
주어지는 모든 입력은 정수이다.
각 $Q$개의 쿼리에 대한 답을 한 줄에 하나씩 출력하여라.
3 3 1 2 2 3 3 1 3 2 1 2 2 3 4 1 3 2 2 2 3 2 2 1 3 2 2
2 2 2 1
예제에서 주어지는 두 그래프는 본문의 그림에 있는 것과 같다.
네 가지 쿼리에 대한 최단경로는 다음 그림 2와 같이 나타낼 수 있다. 첫 번째 쿼리에서는 파란색 실선으로 된 간선만, 두 번째와 세 번째 쿼리에서는 빨간색 점선으로 된 간선만 사용할 수 있고, 마지막 쿼리에서는 모두 사용할 수 있다.
[그림 2] 예제 1의 네 쿼리에서의 최단경로.
3 2 1 2 2 3 3 1 2 3 4 2 1 1 2 1 3 2 2 1 2 3 2
0 -1 -1 -1