[BOJ/C++] 11404 플로이드

GamzaTori·2024년 10월 13일

Algorithm

목록 보기
71/133

출발 노드 ii에서 도착 노드 jj로 가는 최소 비용을 구하는 문제로 플로이드-워셜 알고리즘을 이용해 문제를 해결할 수 있습니다.

  • N이 최대 100 이므로 O(N3)O(N^3)인 플로이드-워셜 알고리즘으로도 가능합니다.

최단 경로 배열을 충분히 큰 값으로 초기화

  • LONG_MAX로 초기화 할 경우 G[i][j]>G[i][k]+G[k][j]G[i][j] > G[i][k] + G[k][j] 부분에서 오른쪽에 오버플로우가 발생
  • 따라서 LONG_MAX가 아닌 충분히 큰 값으로 초기화

노선이 여러 개 일 수도 있으므로 노선 중 가장 작은 값으로 초기화

  • 예를 들어 1 3 5와 1 3 3 이 있다면 1->3 노선의 비용이 작은 3으로 초기화
#include <iostream>
#include <cmath>
#include <algorithm>
#include <vector>
#include <stack>
#include <deque>
#include <queue>
#include <string>
#include <climits>

using namespace std;

using int32 = long;
using int64 = long long;


int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);

    int N, M;
    cin >> N >> M;

    vector<vector<int32>> G;
    G.resize(N + 1, vector<int32>(N + 1, 10000001));

    for (int i = 1; i <= N; i++)
    {
        for (int j = 1; j <= N; j++)
        {
            if (i == j)
                G[i][j] = 0;
        }
    }

    for(int i=0; i<M; i++)
    {
        int s, e, w;
        cin >> s >> e >> w;

        // 시작 도시와 도착 도시를 연결하는 노선이 여러 개 일 수도 있으므로
        // 노선의 비용 중 가장 작은 노선으로 업데이트
        if(G[s][e] > w)
			G[s][e] = w;
    }

    for (int k = 1; k <= N; k++)
    {
        for (int i = 1; i <= N; i++)
        {
            for (int j = 1; j <= N; j++)
            {
                if (G[i][j] > G[i][k] + G[k][j])
                    G[i][j] = G[i][k] + G[k][j];
            }
        }
    }

    for(int i=1; i<=N; i++)
    {
	    for(int j=1; j<=N; j++)
	    {
            if (G[i][j] == 10000001)
                cout << 0 << ' ';
            else
                cout << G[i][j] << ' ';
	    }
        cout << '\n';
    }


    return 0;
}
profile
게임 개발 공부중입니다.

0개의 댓글