KEEP GOING

[python] 이것이코딩테스트다 : 커리큘럼 (위상정렬) 본문

code review/sort

[python] 이것이코딩테스트다 : 커리큘럼 (위상정렬)

jmHan 2022. 1. 10. 15:23
반응형

문제

철수는 라인으로 컴퓨터공학의를 고 있다.

이때 각 온라인의는 의가 있을 수 있는데, 수 의가 있는 의는 수 의를 먼저. 들어야만 해의를 들을 수 있다.

예를들어 '알고리즘’ 강의의  의로 '자료구조' 재한다, ‘자료구조를 들은 이에 ‘알고리즘' 강의를 들을 수 있다.

철수는 총 N 의를  한다. 모든 의는 1부터 N번지의 호를 가진다.

한 동시에 여러 개의 의를 들을 수 있다고 가정한다.

예를 들어 N=3일 때, 3의의 수 의로 1과 2의가 있고, 1과 2의는 의가 다고 가정하.

그리고 각 강의에 대하여 강의 시이 다음과 같다고 가정하.

 

1번 강의: 30시간

2번 강의: 20시간

3번 강의: 40시간

 

이 경우 1번 강의를 수강하기까지의 최소 시간은 30시간, 2번 강의를 수강하기까지의 최소 시간은 20시간, 3번 강의를 수강하기까지의 최소 시간은 70시간이다.

철수가 듣고자 하는 N개의 강의 정보가 주어졌을 때, N개의 강의에 대하여 수강하기까지 걸리는 최소 시간을 각각 출력하는 프로그램을 작성하시오.

 

입력 조건

에 철수가 자 하는 의의 수 N(1≤N≤500)이 주어진다.

다음 N의 에는 각 강의의 의 시과 그. 의를 기 위해 먼저 들어야하는 의들의 호가 수로 주어지며, 각. 자수는 공으로 분한다. 이때 의시은 100,000이하의 수이다 .각 강호는 1부터 N지로 성되며. 각줄은 -1로 다.

 

출력 조건

N개의 강의에 대하여 수강하기까지 걸리는 최소 시간을 한 줄에 하나씩 출력한다

 

입력 예시

5
10 -1
10 1 -1
4 1 -1
4 3 1 -1
3 3 -1

 

출력 예시

10
20
14
18
17

 

 

정답인 코드 

import sys
from collections import deque
sys.stdin = open('curiculum', 'r')
v = int(input())
times = [0]*(v+1)
result = [0]*(v+1)
indegree = [0]*(v+1)
graph = [[] for _ in range(v+1)]

for i in range(1, v + 1):
    lst = list(map(int, input().split()))
    first = lst.pop(0)
    if first == -1:
        continue
    else:
        times[i] = first
    for data in lst:
        if data == -1:
            break
        else:
            indegree[i] += 1
            graph[data].append(i)
# print('ind', indegree)

for i in range(v+1):
    result[i] = times[i]

def topology_sort():
    edges = deque()
    for i in range(1, v+1):
        if indegree[i] == 0:
            edges.append(i)
    # pre = 0
    while edges:
        now = edges.popleft()
        # result.append(times[now] + pre)
        # pre = times[now]
        for i in graph[now]:
            result[i] = max(result[i], result[now]+times[i])
            indegree[i] -= 1
            if indegree[i] == 0:
                edges.append(i)


topology_sort()
# print('ind', indegree)
# print('times', times)
# print('graph', graph)
print(result)
반응형
Comments