Algorithm/DFS & BFS

(Python) - BOJ(1325번) : 효율적인 해킹

하눤석 2022. 3. 31. 14:22
728x90

https://www.acmicpc.net/problem/1325

 

1325번: 효율적인 해킹

첫째 줄에, N과 M이 들어온다. N은 10,000보다 작거나 같은 자연수, M은 100,000보다 작거나 같은 자연수이다. 둘째 줄부터 M개의 줄에 신뢰하는 관계가 A B와 같은 형식으로 들어오며, "A가 B를 신뢰한

www.acmicpc.net


  • 문제 : 

해커 김지민은 잘 알려진 어느 회사를 해킹하려고 한다. 이 회사는 N개의 컴퓨터로 이루어져 있다. 김지민은 귀찮기 때문에, 한 번의 해킹으로 여러 개의 컴퓨터를 해킹 할 수 있는 컴퓨터를 해킹하려고 한다.

이 회사의 컴퓨터는 신뢰하는 관계와, 신뢰하지 않는 관계로 이루어져 있는데, A가 B를 신뢰하는 경우에는 B를 해킹하면, A도 해킹할 수 있다는 소리다.

이 회사의 컴퓨터의 신뢰하는 관계가 주어졌을 때, 한 번에 가장 많은 컴퓨터를 해킹할 수 있는 컴퓨터의 번호를 출력하는 프로그램을 작성하시오.

 

 

 


  • 풀이 :

주어진 N의 범위가 10,000이고 M의 범위가 100,000이므로 시간초과에 간당간당하게 안걸렸다.

A,B가 주어질 때, B -> A 쪽으로 그래프의 간선을 연결하고 1부터 N까지 모든 노드에 대해 갈 수 있는 노드의 개수를 카운팅한다.  이 값이 max일 경우에만 시작노드를 정답배열에 넣어 마지막에 출력하면 된다. 

 

 

 


  • 소스코드 : 
import sys
from collections import deque
def bfs(start):
    queue = deque()
    queue.append(start)
    check = [0]*(N+1)
    check[start] = 1
    while queue:
        X = queue.popleft()
        for Y in trust[X]:
            if check[Y] == 0:
                check[Y] = 1
                queue.append(Y)
    return sum(check)


if __name__ == "__main__":
    N,M = map(int,sys.stdin.readline().split())
    trust = [[] for _ in range(N+1)]
    answer = []
    m = 0
    for _ in range(M):
        x,y = map(int,sys.stdin.readline().split())
        trust[y].append(x)
    for start in range(1,N+1):
        x = bfs(start)
        if m < x:
            answer = [start]
            m = x
        elif m == x:
            answer.append(start)
    print(' '.join(map(str,answer)))
320x100