본문 바로가기
Algorythms

백준 15971번 두 로봇 c++ 풀이

by 준형코딩 2024. 1. 30.

문제

2018년 강원도에서 새로운 동굴이 발견되었다. 이 동굴에는 총 N개의 넓은 방이 존재하며 좁은 통로로 서로 연결되어 있는 것으로 밝혀졌다. N개의 방은 1번부터 N번까지의 번호를 붙여 1번 방, 2번 방, …, N번 방으로 부른다. 통로는 정확히 N-1개가 발견되었는데, 각각 서로 다른 두 방 사이를 연결시켜 주며 중간에 다른 통로와 이어지는 경우는 없다고 한다. 또한 이 통로들을 이용하여 임의의 두 방 사이를 이동하는 것이 가능하며, 임의의 두 방 사이를 이동할 때 같은 통로를 두 번 이상 지나지 않는 경로는 유일한 것으로 밝혀졌다.

새로 발견된 동굴을 조사하기 위해 동굴 탐사 로봇 두 대를 이용하기로 하였다. 두 로봇은 어떤 시점이 되면 각자가 획득한 정보를 공유하기 위해 통신을 해야 한다. 두 로봇이 서로 통신을 하기 위해서는 동굴 내의 같은 통로 위에 위치해야만 한다. 참고로 임의의 통로의 양 끝에 위치한 두 방들도 그 통로 위에 위치해 있다고 간주한다.


<그림 1> 동굴 내부를 간략히 표현한 그림

<그림 1>은 방이 9개인 동굴 내부를 간략하게 나타낸 예이다. <그림 1>에서 방은 원으로 표현되어 있으며 원 안의 수는 방 번호이다. 8개의 통로는 두 원 사이의 선분으로 표시되어 있으며 그 위의 정수 값이 통로의 길이이다. 예를 들어, 5번 방과 9번 방 사이에 길이가 6 인 통로가 있음을 알 수 있다. 만약 두 로봇이 1번 방과 9번 방에 위치해 있다면, 각각 2번 방과 5번 방으로 이동한 후 통신할 수 있으며 이때 이동한 거리의 합은 14로 최소이다.

동굴 내의 통로에 대한 정보와 두 로봇의 현재 위치가 입력으로 주어질 때, 서로 통신하기 위해 이동해야 하는 거리의 합의 최솟값을 계산하는 프로그램을 작성하시오.

동굴의 각 통로는 양 끝에 위치한 두 방의 번호와 그 길이로 주어진다. 두 로봇의 위치는 방 번호로 주어진다.

입력

표준 입력으로 동굴의 방의 개수 N과 두 로봇이 위치한 방의 번호가 세 개의 양의 정수로 공백으로 분리되어 첫 줄에 주어진다. 이후 동굴의 통로 N-1개가 한 줄에 하나씩 주어진다. 각 통로는 세 개의 양의 정수로 공백으로 분리되어 한 줄에 주어지며, 앞 두 정수는 통로의 양 끝에 위치한 방의 번호를, 세 번째 정수는 그 통로의 길이를 의미한다.

출력

표준 출력으로 두 로봇이 서로 통신하기 위해 현재 위치에서 이동해야 하는 거리의 합의 최솟값을 정수로 출력한다.

제한

모든 서브태스크에서 1 ≤ N ≤ 100,000이며, 통로의 길이는 1,000을 넘지 않는다.

서브태스크 1 (17점)

입력에서 두 번째 줄에 주어지는 방번호는 1과 2, 세 번째 줄에 주어지는 방 번호는 2와 3, …, i번째 줄에 주어지는 방 번호는 i-1과 i, …, N번째 줄에 주어지는 방 번호는 N-1과 N이다 (아래 입력과 출력의 예에서 예제 입력 1을 참고).

서브태스크 2 (19점)

동굴 내의 통로의 길이가 모두 1이다.

서브태스크 3 (23점)

N ≤ 5,000이다.

서브태스크 4 (41점)

공통조건 이외에 제약조건이 없다.

예제 입력 1 복사

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

예제 출력 1 복사

6

예제 입력 2 복사

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

예제 출력 2 복사

14
 
두 로봇 사이의 거리를 구한 후 최대의 거리를 빼면 정답이 되는 문제.
처음에 문제를 잘못 이해해서 두 로봇이 동시에 움직여야 한다고 생각했으나 이 문제는 동시에 움직이는 것을 생각해야 할 만큼의 난이도 문제가 아니었고 두 로봇이 통로에서 마주칠 때까지 양쪽에서 원하는만큼 움직여도 되어서 최소 거리를 구하기 위해서는 그저 두 로봇 사이의 거리를 구한 후 최대의 거리를 빼기만 하면 정답이 되는 문제였다. 문제를 잘 이해하자.
- c++ 풀이
#include <bits/stdc++.h>

using namespace std;

struct roomCondition {
    int number;
    int distance;
    int depth;
    int sum;
    int maxDistance;
};

int n, room1, room2;
vector<roomCondition> v[100001];
int visited[100001];


void bfs(int start, int to) {

    queue<roomCondition> q;
    q.push({start, 0});
    visited[start] = 1;

    while (!q.empty()) {
        int currentIndex = q.front().number;
        int currentDepth = q.front().depth;
        int currentSum = q.front().sum;
        int maxDistance = q.front().maxDistance;
        q.pop();


        if (currentIndex == to) {

            cout << currentSum - maxDistance << "\n";
            return;
        }


        for (int i = 0; i < v[currentIndex].size(); i++) {
            int newIndex = v[currentIndex][i].number;
            int newDistance = v[currentIndex][i].distance;


            if (visited[newIndex] == 0) {
                visited[newIndex] = 1;
                q.push({newIndex, newDistance, currentDepth + 1, currentSum + newDistance,
                        max(newDistance, maxDistance)});
            }


        }

    }


}


int main() {
    ios::sync_with_stdio(false);
    cin.tie(NULL);

    cin >> n >> room1 >> room2;

    for (int i = 0; i < n - 1; i++) {
        int start, to, distance;
        cin >> start >> to >> distance;
        v[start].push_back({to, distance, 0, 0});
        v[to].push_back({start, distance, 0, 0});
    }

    bfs(room1, room2);


}

 

 
   

 

'Algorythms' 카테고리의 다른 글

백준 2628번 종이자르기 c++ 풀이  (1) 2024.01.30
백준 10158번 개미 c++ 풀이  (1) 2024.01.30
백준 2343번 기타 레슨 c++ 풀이  (0) 2024.01.29
백준 17609번 회문 c++ 풀이  (3) 2024.01.28
백준 1786번 찾기 c++ 풀이  (1) 2024.01.28