Skip to content

Conversation

@froglike6
Copy link
Collaborator

@froglike6 froglike6 commented Apr 9, 2025

๐Ÿ”— ๋ฌธ์ œ ๋งํฌ

์ตœ์†Œ๋น„์šฉ ๊ตฌํ•˜๊ธฐ

โœ”๏ธ ์†Œ์š”๋œ ์‹œ๊ฐ„

1์‹œ๊ฐ„

โœจ ์ˆ˜๋„ ์ฝ”๋“œ

์ˆ˜๋„์ฝ”๋“œ

ํ•จ์ˆ˜ ๋‹ค์ต์ŠคํŠธ๋ผ(๋…ธ๋“œ๊ฐœ์ˆ˜ n, ๊ทธ๋ž˜ํ”„, ์‹œ์ž‘๋…ธ๋“œ start):
    ๋ฌดํ•œ๋Œ€(INF)๋ฅผ ์ •์˜ํ•œ๋‹ค.
    ๋ชจ๋“  ๋…ธ๋“œ์— ๋Œ€ํ•œ ์ตœ๋‹จ ๊ฑฐ๋ฆฌ ๋ฐฐ์—ด distances๋ฅผ INF๋กœ ์ดˆ๊ธฐํ™” (์ธ๋ฑ์Šค 0๋ถ€ํ„ฐ n๊นŒ์ง€)
    distances[start] = 0  // ์‹œ์ž‘๋…ธ๋“œ์˜ ๊ฑฐ๋ฆฌ๋Š” 0์œผ๋กœ ์„ค์ •
    ์šฐ์„ ์ˆœ์œ„ ํ(queue)์— (0, start) ํŠœํ”Œ์„ ๋„ฃ๋Š”๋‹ค.

    ํ๊ฐ€ ๋นŒ ๋•Œ๊นŒ์ง€ ๋ฐ˜๋ณต:
        ํ์—์„œ (ํ˜„์žฌ๋น„์šฉ, ํ˜„์žฌ๋…ธ๋“œ)๋ฅผ ๊บผ๋‚ธ๋‹ค.
        ๋งŒ์•ฝ ํ˜„์žฌ๋น„์šฉ์ด ์ด๋ฏธ ์ €์žฅ๋œ distances[ํ˜„์žฌ๋…ธ๋“œ]๋ณด๋‹ค ํฌ๋‹ค๋ฉด, ์ด๋ฏธ ๋” ์ข‹์€ ๊ฒฝ๋กœ๊ฐ€ ์žˆ์œผ๋ฏ€๋กœ ์ด๋ฒˆ ๋ฐ˜๋ณต ๊ฑด๋„ˆ๋›ด๋‹ค.
        ํ˜„์žฌ๋…ธ๋“œ์˜ ์ด์›ƒ ๋…ธ๋“œ๋“ค์„ ์ˆœํšŒ:
            (๋‹ค์Œ๋…ธ๋“œ, ๊ฐ€์ค‘์น˜) ๊ฐ๊ฐ์— ๋Œ€ํ•˜์—ฌ:
                ๋ˆ„์ ๋น„์šฉ = ํ˜„์žฌ๋น„์šฉ + ๊ฐ€์ค‘์น˜
                ๋งŒ์•ฝ ๋ˆ„์ ๋น„์šฉ์ด distances[๋‹ค์Œ๋…ธ๋“œ]๋ณด๋‹ค ์ž‘๋‹ค๋ฉด:
                    distances[๋‹ค์Œ๋…ธ๋“œ] = ๋ˆ„์ ๋น„์šฉ (๋” ๋‚˜์€ ๊ฒฝ๋กœ ๋ฐœ๊ฒฌ!)
                    ํ์— (๋ˆ„์ ๋น„์šฉ, ๋‹ค์Œ๋…ธ๋“œ)๋ฅผ ์ถ”๊ฐ€ํ•œ๋‹ค.
    ํ•จ์ˆ˜ ์ข…๋ฃŒ ํ›„, distances ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

๋ฉ”์ธ ์‹คํ–‰ ๋ถ€๋ถ„:
    ํ‘œ์ค€ ์ž…๋ ฅ์œผ๋กœ๋ถ€ํ„ฐ ๋…ธ๋“œ์˜ ๊ฐœ์ˆ˜ N์„ ์ž…๋ ฅ ๋ฐ›๋Š”๋‹ค.
    ๊ฐ„์„ (๊ฒฝ๋กœ)์˜ ๊ฐœ์ˆ˜ M์„ ์ž…๋ ฅ ๋ฐ›๋Š”๋‹ค.
    ๋…ธ๋“œ1๋ถ€ํ„ฐ ๋…ธ๋“œN๊นŒ์ง€์˜ ์ธ์ ‘ ๋ฆฌ์ŠคํŠธ ํ˜•ํƒœ์˜ ๊ทธ๋ž˜ํ”„๋ฅผ ์ดˆ๊ธฐํ™”ํ•œ๋‹ค.

    M๋ฒˆ ๋ฐ˜๋ณต:
        ๊ฐ ์ค„๋กœ๋ถ€ํ„ฐ u, v, w๋ฅผ ์ž…๋ ฅ ๋ฐ›๋Š”๋‹ค. (u์—์„œ v๋กœ ๊ฐ€๋Š” ๊ฒฝ๋กœ์˜ ๊ฐ€์ค‘์น˜ w)
        ๊ทธ๋ž˜ํ”„[u] ๋ฆฌ์ŠคํŠธ์— (v, w)๋ฅผ ์ถ”๊ฐ€ํ•œ๋‹ค.

    ์‹œ์ž‘ ๋…ธ๋“œ์™€ ๋„์ฐฉ ๋…ธ๋“œ๋ฅผ ์ž…๋ ฅ ๋ฐ›๋Š”๋‹ค.
    ๋‹ค์ต์ŠคํŠธ๋ผ ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜์—ฌ ์‹œ์ž‘ ๋…ธ๋“œ๋กœ๋ถ€ํ„ฐ ๋„์ฐฉ ๋…ธ๋“œ๊นŒ์ง€ ์ตœ๋‹จ ๊ฒฝ๋กœ๋ฅผ ๊ตฌํ•œ๋‹ค.
    ๋„์ฐฉ ๋…ธ๋“œ์˜ ์ตœ๋‹จ ๊ฒฝ๋กœ ๊ฐ’์„ ์ถœ๋ ฅํ•œ๋‹ค.

์ด ๋ฌธ์ œ๋Š” ๋‹ค์ต์ŠคํŠธ๋ผ์˜ ์ •์„ ๊ฐ™์€ ๋ฌธ์ œ์ž…๋‹ˆ๋‹ค. ๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜์€ ๋จผ์ € ๋ชจ๋“  ๊ฐ„์„ ์˜ ๊ฐ€์ค‘์น˜๋ฅผ ๋ฌดํ•œ๋Œ€๋กœ ๋‘๊ณ  ์‹œ์ž‘ํ•ฉ๋‹ˆ๋‹ค. ๊ทธ๋Ÿฐ ๋‹ค์Œ ๋ชจ๋“  ๋…ธ๋“œ๋ฅผ ํƒ์ƒ‰ํ•˜๋ฉฐ ์–ด๋–ค ๋…ธ๋“œ์—์„œ ๋‹ค๋ฅธ ๋…ธ๋“œ๋กœ ๊ฐˆ ๋•Œ์˜ ์ตœ์†Œ ๊ฐ€์ค‘์น˜๋ฅผ ์ €์žฅํ•ฉ๋‹ˆ๋‹ค. ์ด๋ ‡๊ฒŒ ๋ชจ๋“  ๋…ธ๋“œ๋ฅผ ํƒ์ƒ‰ ์™„๋ฃŒํ•˜๋ฉด ํŠน์ • ๋…ธ๋“œ์—์„œ ๋‹ค๋ฅธ ํŠน์ • ๋…ธ๋“œ๋กœ ๊ฐˆ ๋•Œ์˜ ์ตœ์†Œ ๊ฐ€์ค‘์น˜๋ฅผ ์•Œ ์ˆ˜ ์žˆ๊ฒŒ ๋ฉ๋‹ˆ๋‹ค.
dijkstra

๋ฌธ์ œ์—์„œ ์ถœ๋ฐœ์ ๊ณผ ๋„์ฐฉ์ ์ด ๋‚˜์™€์žˆ๊ธฐ ๋•Œ๋ฌธ์—, ๋„์‹œ๋“ค๊ณผ ๋ฒ„์Šค ๋น„์šฉ์„ ๋…ธ๋“œ์™€ ๊ฐ€์ค‘์น˜๋กœ ์‚ผ์•„ ๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ๊ทธ๋ ‡๊ฒŒ ํ•ด์„œ ๋‚˜์˜จ ์ตœ์†Œ ๊ฐ€์ค‘์น˜๊ฐ€ ๋ฒ„์Šค๊ฐ€ ์ด๋™ํ•  ๋•Œ์˜ ์ตœ์†Œ๋น„์šฉ์ด ๋˜๊ฒŒ ๋ฉ๋‹ˆ๋‹ค.

์„ค๋ช…์„ ์ ๊ธด ์ ์—ˆ๋Š”๋ฐ ๋ถ€์กฑํ•ด๋ณด์ด๋„ค์š”..ใ… ใ…  ํ˜น์‹œ๋‚˜ ๋ชจ๋ฅด๋Š” ๋ถ€๋ถ„ ์žˆ์œผ๋ฉด comment ๋‹ฌ์•„์ฃผ์„ธ์š” ใ…Žใ…Ž

๐Ÿ“š ์ƒˆ๋กญ๊ฒŒ ์•Œ๊ฒŒ๋œ ๋‚ด์šฉ

@froglike6 froglike6 self-assigned this Apr 9, 2025
@froglike6 froglike6 marked this pull request as ready for review April 9, 2025 14:16
@froglike6 froglike6 changed the base branch from 6-froglike6 to main April 11, 2025 08:15
Copy link
Collaborator

@caucsejunseo caucsejunseo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์ฒ˜์Œ ๋ดค๋Š”๋ฐ ์ด์ „์— ๋ดค๋˜ dp๋ž‘ ์œ ์‚ฌํ•˜๋‹จ ์ƒ๊ฐ์ด ๋“ค์–ด ์ฐพ์•„๋ณด๋‹ˆ ๋‹ค์ต์ŠคํŠธ๋ผ ๋ฌธ์ œ์— dp๋ฌธ์ œ๊ฐ€ ํฌํ•จ๋œ๋‹ค๊ณ  ํ•˜๋„ค์š”

"๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜์ด ๋‹ค์ด๋‚˜๋ฏน ํ”„๋กœ๊ทธ๋ž˜๋ฐ ๋ฌธ์ œ์ธ ์ด์œ ๋Š” '์ตœ๋‹จ ๊ฑฐ๋ฆฌ๋Š” ์—ฌ๋Ÿฌ ๊ฐœ์˜ ์ตœ๋‹จ ๊ฑฐ๋ฆฌ๋กœ ์ด๋ฃจ์–ด์ ธ์žˆ๊ธฐ ๋•Œ๋ฌธ'์ž…๋‹ˆ๋‹ค" ๋ผ๋„ค์š”!

์ œ๊ฐ€ ๋А๋‚€ dp๋ฌธ์ œ์™€ ์œ ์‚ฌํ•œ ์ ์€ ์ด์ „์˜ ๊ฐ’๋“ค ์ค‘ ์ตœ์†Œ์ธ ๊ฐ’๋งŒ ๊ธฐ์–ตํ•˜๊ณ  ๋น„๊ตํ•œ๋‹ค๋Š” ์ ์—์„œ ๋งŽ์ด ์œ ์‚ฌํ•จ์„ ๋А๊ผˆ๋˜๊ฑฐ ๊ฐ™์Šต๋‹ˆ๋‹ค

heapq.heappush(queue, (cost, next_node))

push(&pq, cost, next_node);
ํ ๊ณต๋ถ€ํ–ˆ๋˜ ๊ธฐ์–ต์œผ๋กœ c์–ธ์–ด๋กœ ์‚ด์ง ๋ฐ”๊ฟ”๋ดค์Šต๋‹ˆ๋‹ค ใ…Ž

@dohyeondol1
Copy link
Contributor

๋ฌธ์ œ ๋„์ „ํ•ด๋ณด๊ณ  ์žˆ๋Š”๋ฐ ์•„์ง ์–ด๋ ค์›Œ์„œ ๋‚ด์ผ ์ค‘์œผ๋กœ ๋ฆฌ๋ทฐ ์™„๋ฃŒํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค...!! ๐Ÿฅฒ

Copy link
Collaborator

@hadongun hadongun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

์ฒ˜์Œ ๋ณด๋Š” ๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜์ด๋ผ ์ด๊ฒƒ์ €๊ฒƒ ์ฐพ์•„๋ณด๋ฉด์„œ ๊ณต๋ถ€ํ•ด๋ดค์–ด์š”..
์šฐ์„ ์ˆœ์œ„ ํ ์—†์ด ๊ตฌํ˜„ํ•˜๋Š” ์ฝ”๋“œ๋ฅผ ๊ณต๋ถ€ํ–ˆ๋Š”๋ฐ, ๋„ํ˜„๋‹˜์€ ์šฐ์„ ์ˆœ์œ„ ํ๋ฅผ ์‚ฌ์šฉํ•˜์…จ๋”๊ตฐ์š”!
์šฐ์„ ์ˆœ์œ„ ํ ์—†์ด ๊ตฌํ˜„ํ•˜๋ฉด ๋งค๋ฒˆ ๋ชจ๋“  ์ •์ ์„ ํƒ์ƒ‰ํ•ด์„œ ๋น„ํšจ์œจ์ ์ด๋„ค์š”.. ์•„์ง ์™„์ „ํ•œ ์ดํ•ด๋ฅผ ๋ชป ํ•ด์„œ ๋น„์Šทํ•œ ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ๊ณ„์† ์ ‘ํ•ด๋ณด๋ฉด์„œ ์ดํ•ด๋„๋ฅผ ๋†’์—ฌ๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค

Copy link
Contributor

@dohyeondol1 dohyeondol1 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

์šฐ์„ ์ˆœ์œ„ ํ ๋ฌธ์ œ๋ฅผ ๋ช‡ ๊ฐœ ํ’€์–ด๋ณด๋ฉด์„œ ์šฐ์„ ์ˆœ์œ„ ํ๋ฅผ ๋จผ์ € ์ดํ•ดํ•˜๊ณ  ๋ฐ”๋กœ ๋ฌธ์ œ๋ฅผ ๋„์ „ํ–ˆ์Šต๋‹ˆ๋‹ค.

์ดํ•ดํ•˜๊ณ  ๋ณด๋‹ˆ ๊ทธ๋ ‡๊ฒŒ ์–ด๋ ค์šด ๊ฐœ๋…์€ ์•„๋‹ˆ๋ผ๊ณ  ์ƒ๊ฐํ•˜๋Š”๋ฐ
์—ญ์‹œ ์ฝ”๋“œ๋กœ ์ง์ ‘ ๊ตฌํ˜„ํ•ด๋ณด๋ฉด์„œ ๋А๋ผ๋‹ˆ๊นŒ ๋‹ค๋ฆ…๋‹ˆ๋‹ค...
๋ง‰์ƒ ์ƒ๊ฐ๋Œ€๋กœ ๋น ๋ฅด๊ฒŒ ํ’€๋ฆฌ์ง„ ์•Š์•˜๋˜ ๊ฒƒ ๊ฐ™๋„ค์š”..

์ •์„์ ์ธ ๋ฌธ์ œ๋ผ ๊ทธ๋Ÿฐ์ง€ ๋„ํ˜„๋‹˜์˜ ์ฝ”๋“œ๋ž‘ ๊ฑฐ์˜ ๋˜‘๊ฐ™์€ ํ’€์ด์ž…๋‹ˆ๋‹ค.
์ฝ”๋“œ๋ฅผ ๋ด๋„ ๋ฆฌ๋ทฐ๋ฅผ ํ• ๋งŒํ•œ ๊ฒŒ ์•ˆ๋ณด์ด๋„ค์š” ใ…Ž

C++
#include <iostream>
#include <vector>
#include <queue>
using namespace std;

int main() {
    cin.tie(nullptr)->sync_with_stdio(false);

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

    vector<vector<pair<int, int>>> graph(N + 1);
    for(int i = 0; i < M; ++i) {
        int u, v, w;
        cin >> u >> v >> w;
        graph[u].emplace_back(v, w);
    }

    int start, end;
    cin >> start >> end;

    vector<int> distance(N + 1, 1e9);
    priority_queue<pair<int, int>, vector<pair<int, int>>, greater<>> pq;
    distance[start] = 0;
    pq.push({0, start});

    while(!pq.empty()) {
        int cost = pq.top().first;
        int current = pq.top().second;
        pq.pop();

        if(distance[current] < cost) continue;

        for(auto [next, weight] : graph[current]) {
            if(distance[current] + weight < distance[next]) {
                distance[next] = distance[current] + weight;
                pq.push({distance[next], next});
            }
        }
    }

    cout << distance[end] << '\n';
    return 0;
}

(์ด ๋ฌธ์ œ๋ฅผ ํ’€๋ฉด์„œ ์ €๋ฒˆ์— ๋ฐฐ์› ๋˜ structured binding์„ ์‚ฌ์šฉํ•ด๋ณด์•˜์Šต๋‹ˆ๋‹ค. ใ…Žใ…Ž)
๋•๋ถ„์— ์šฐ์„ ์ˆœ์œ„ ํ๋„ ๊ณต๋ถ€ํ•˜๊ณ  ๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜๋„ ๊ณต๋ถ€ํ•˜๊ฒŒ ๋˜์–ด ์œ ์ตํ–ˆ์Šต๋‹ˆ๋‹ค :)

@froglike6 froglike6 merged commit 8b91ac3 into main May 1, 2025
1 check passed
@dohyeondol1 dohyeondol1 deleted the 7-froglike6 branch May 10, 2025 18:54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants