코드
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
int n,m,indegree[1003],x,y, visited[1003];
vector<int> adj[1003];
int main() {
cin >> n >> m;
for(int i = 0; i < m; i++) {
cin >> x >> y;
adj[x].push_back(y);
indegree[y]++;
}
queue<int> q;
for(int i = 1; i < n + 1; i++) {
if(indegree[i] == 0) {
q.push(i);
visited[i] = 1;
}
}
// 위상정렬
while(q.size()) {
int pn = q.front();
q.pop();
for(int i : adj[pn]) {
indegree[i]--;
if(indegree[i] == 0) {
visited[i] = visited[pn] + 1;
q.push(i);
}
}
}
for(int i = 1; i < n + 1; i++) {
cout << visited[i];
if(i != n) cout << " ";
}
cout << '\n';
return 0;
}
풀이
선수과목 문제는 전형적인 위상정렬 문제이다. 몇 번째에 듣는지가 중요했는데, visited 배열을 이용해서 방문 순서를 체크해주면 된다.왜 저번엔 이게 그렇게 기억이 안났지... 오늘은 그냥 한 번에 생각났는데. 알기 힘들다 진짜.
'백준' 카테고리의 다른 글
[백준] 10942번 팰린드롬? C++ 코드 (1) | 2024.09.16 |
---|---|
[백준] 1344번 축구 C++ 코드 (1) | 2024.09.16 |
[백준] 11055번 가장 큰 증가하는 부분 수열 C++ 코드 (0) | 2024.09.15 |
[백준] 1600번 말이 되고픈 원숭이 C++ 코드 (1) | 2024.09.08 |
[백준] 16435번 스네이크버드 C++ 코드 (0) | 2024.09.08 |