[BOJ 2623 / C++] 음악프로그램 (위상정렬)

2025. 8. 13. 23:02·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/2623

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

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

    int n, m;
    cin >> n >> m;

    vector<vector<int>> adj(n+1);
    vector<int> deg(n+1, 0);

    for (int i = 0; i < m; i++) {
        int num;
        cin >> num;
        vector<int> tmp(num);
        for (int j = 0; j < num; j++) {
            cin >> tmp[j];
        }

        for (int j = 0; j < num-1; j++) {
            adj[tmp[j]].push_back(tmp[j+1]);
            deg[tmp[j+1]]++;
        }
    }

    queue<int> Q;
    vector<int> result;

    for (int i = 1; i <= n; i++) {
        if (deg[i] == 0) Q.push(i);
    }

    while (!Q.empty()) {
        int cur = Q.front(); Q.pop();
        result.push_back(cur);
        for (int nxt : adj[cur]) {
            deg[nxt]--;
            if (deg[nxt] == 0) Q.push(nxt);
        }
    }

    if (result.size() != n) {
        cout << 0;
    }
    else {
        for (int p : result) {
            cout << p << '\n';
        }
    }
}

 

 

2. 시간복잡도

위상정렬의 시간복잡도는 O(n+e)에 동작한다. 문제에서 n = 1000 이하 정수이고 간선 개수 e = m*100이므로 연산 횟수는 2000 < 10^8이므로 시간제한 1초내에 통과 가능하다.

 

 

3. 분석

전형적인 위상정렬 문제이다. 입력을 받을 때 전체를 입력받아놓고 adjacent_list에 하나씩 정점과 간선 정보를 입력해주면 된다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ 1197 / C++] 최소 스패닝 트리 (최소 신장 트리)  (0) 2025.08.15
[BOJ 5567 / C++] 결혼식 (그래프)  (1) 2025.08.15
[BOJ 2252 / C++] 줄 세우기 (위상정렬)  (0) 2025.08.13
[BOJ 4803 / C++] 트리 (트리)  (0) 2025.08.12
[BOJ 2606 / C++] 바이러스 (그래프)  (0) 2025.08.12
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ 1197 / C++] 최소 스패닝 트리 (최소 신장 트리)
  • [BOJ 5567 / C++] 결혼식 (그래프)
  • [BOJ 2252 / C++] 줄 세우기 (위상정렬)
  • [BOJ 4803 / C++] 트리 (트리)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (173) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (0)
      • 코딩테스트 (96) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ 2623 / C++] 음악프로그램 (위상정렬)
상단으로

티스토리툴바