프로그램 명: koi_contact
제한시간: 1 초

산골에 N 개의 마을이 있으며 각각 두 마을을 잇는 M 개의 도로가 있다. 이 도로들은 전체 마을 들을 모두 연결하고 있다. 즉, 어떤 마을에서든 다른 마을로 (하나 이상의 도로를 거쳐서) 갈 수 있다. 또한 어떤 인접한 두 마을은 두 개 이상의 도로로 바로 연결되기도 한다. 여러 가지 급한 상황이 생길 수 있기 때문에 전체 마을들을 연결하 는 비상연락망을 구성하여 급한 상황을 알리기로 하였다. 비상연락망에 들어가는 도로의 경우에는 특별히 잘 관리해야 하므로 각 도로마다 관리 비 용이 발생한다. 물론 비상연락망은 전체 관리 비용이 최소가 되도록 만든다.

이 지역에는 가끔 산사태가 발생하는데, 산사태가 발생하여 특정한 도로가 통행 불가능이 될 수 있다. 다행히도 통행 불가능이 되는 경우 오직 하나의 도로만이 그렇게 된다고 한다. 그러한 상황에 대비하기 위해서 각 도로마다, 그 도로가 통행 불가능이 되었다고 가정하고 비상연 락망을 구성할 경우 전체 최소 비용이 얼마가 되는지 알고 싶다.

마을의 수와 연결하는 도로들, 그리고 각 도로에 해당하는 비용을 입력으로 받아서 각각의 도로에 대해서 그 도로가 통행 불가능인 경우의 비상연락망을 구성하는 최소 비용을 출력하는 프로그램을 작성하라.

수행 시간은 1초를 넘을 수 없다. 메모리 제한은 64MB이다.

입력

출력

출력에는 M 개의 줄이 있어야하며, 각 줄에는 하나의 자연수가 있어야 한다. I 번째 줄에는 입력에 I 번째로 주어진 도로가 통행 불가능인 경우 비상연락망의 최소 비용을 자연수로 출력한다. 단, 비상연락망이 존재하지 않는다면 -1을 출력해야 한다. 비용의 값이 커질 수 있으므로 64비트 정수 변수 (long long type)를 사용해야 할 수도 있음에 주의하라.

입출력 예

입력

5 9
1 2 1
3 1 4
4 3 6
2 4 7
2 5 2
5 3 5
1 5 3
5 4 7
2 4 8

출력

15
14
14
13
14
13
13
13
13

입력

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

출력

-1
6
5
6
출처: 제31회 한국정보올림피아드 전국본선 (2014.7.11) 고등부 문제 4
대회 풀이
[질/답] [제출 현황] [푼 후(0)]
[ 채 점 ] [홈으로]  [뒤 로]