728x90
🔗 Problem Link
1389번: 케빈 베이컨의 6단계 법칙
첫째 줄에 유저의 수 N (2 ≤ N ≤ 100)과 친구 관계의 수 M (1 ≤ M ≤ 5,000)이 주어진다. 둘째 줄부터 M개의 줄에는 친구 관계가 주어진다. 친구 관계는 A와 B로 이루어져 있으며, A와 B가 친구라는 뜻
www.acmicpc.net
❔Thinking
- N명의 사람에 대한 친구관계가 주어질 때, 베이컨 법칙에 따른 총합이 제일 적은 사람을 반환한다.
💻Solution
1. 플로이드-워셜을 활용한 풀이
import sys
input = sys.stdin.readline
INF = int(1e9)
n, m = map(int, input().split())
graph = [[INF] * (n+1) for _ in range(n+1)]
# 친구관계 입력
for _ in range(m):
a, b = map(int, input().split())
graph[a][b] = 1
graph[b][a] = 1
# 케빈 베이컨 계산 (플로이드-워셜)
for k in range(1, n+1):
for i in range(1, n+1):
for j in range(1, n+1):
graph[i][j] = min(graph[i][j], graph[i][k]+graph[k][j])
# 케빈 베이컨 총합이 가장 작은 사람
bacon = INF
result = 0
for i in range(1, n+1):
tmp = sum(graph[i][1:])
if bacon > tmp:
bacon = tmp
result = i
print(result)
2. DFS(깊이 우선 탐색)을 활용한 풀이
import sys
from collections import defaultdict, deque
input = sys.stdin.readline
INF = int(1e9)
n, m = map(int, input().split())
result_u = 0
result_bacon = INF
friends = defaultdict(list)
for _ in range(m):
a, b = map(int, input().split())
friends[a].append(b)
friends[b].append(a)
for u in range(1, n+1):
bacon = {u:0}
q = deque([u])
while q:
now = q.popleft()
for next_u in friends[now]:
if next_u not in bacon:
bacon[next_u] = bacon[now]+1
q.append(next_u)
now_bacon = sum(bacon.values())
if result_bacon > now_bacon:
result_bacon = now_bacon
result_u = u
print(result_u)
🗝️keypoint
- N이 100이하로 작기 때문에, 플로이드-워셜을 활용한 풀이가 가능하다.
- N명의 사람이 자기 자신을 제외한 다른 모든 사람과의 몇 단계를 통해 이어지는지 확인하는것이 중요하다.
'코딩테스트 > Python' 카테고리의 다른 글
GCD(Great Common Divisior), LCM(Least Common Multiple) (1) | 2023.03.24 |
---|---|
[Baekjoon] 1992. 쿼드트리 (0) | 2023.01.30 |
[Programmers] Level 3. 경주로 건설 (0) | 2023.01.20 |
[Baekjoon] 1012. 유기농 배추 (1) | 2023.01.20 |
[Programmers] Level 3. 합승 택시 요금 (0) | 2023.01.19 |