位 : 자리 위
相 : 서로 상어떤 사물이 다른 사물과의 관계 속에서 가지는 위치나 상태.
사이클이 없는 방향 그래프의 모든 노드를 방향성에 거스르지 않도록 순서대로 나열하는 것을 의미합니다.
- 진입차수(Indegree)
특정한 노드로 들어오는 간선의 개수
- 진출차수(Outdegree)
특정한 노드에서 나가는 간선의 개수
// 모든 노드에 대한 진입차수를 저장하는 배열
public static int[] indegree = new int[100001];
// 연결 리스트
public static ArrayList<ArrayList<Integer>> graph = new ArrayList<ArrayList<Integer>>();
// 위상 정렬 함수
public static void topologySort() {
ArrayList<Integer> result = new ArrayList<>(); // 알고리즘 수행 결과를 담을 리스트
Queue<Integer> q = new LinkedList<>();
// 처음 시작할 때는 진입차수가 0인 노드를 큐에 삽입
for (int i = 1; i <= v; i++) {
if (indegree[i] == 0) {
q.offer(i);
}
}
// 큐가 빌 때까지 반복
while (!q.isEmpty()) {
// 큐에서 원소 꺼내기
int now = q.poll();
result.add(now);
// 해당 원소와 연결된 노드들의 진입차수에서 1 빼기
for (int i = 0; i < graph.get(now).size(); i++) {
indegree[graph.get(now).get(i)] -= 1;
// 새롭게 진입차수가 0이 되는 노드를 큐에 삽입
if (indegree[graph.get(now).get(i)] == 0) {
q.offer(graph.get(now).get(i));
}
}
}
// 위상 정렬을 수행한 결과 출력
for (int i = 0; i < result.size(); i++) {
System.out.print(result.get(i) + " ");
}
}
위상 정렬의 시간 복잡도는 입니다.
큐를 이용한 방식에서는 각 노드를 큐에 한 번씩 넣고 꺼내므로 시간이 걸리고, 각 간선을 한 번씩 처리하여 진입차수를 갱신하므로 시간이 걸립니다.