[Baekjoon] 1389. 케빈 베이컨의 6단계 법칙

2023. 1. 30. 16:19·코딩테스트/Python
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

  1. N이 100이하로 작기 때문에, 플로이드-워셜을 활용한 풀이가 가능하다.
  2. N명의 사람이 자기 자신을 제외한 다른 모든 사람과의 몇 단계를 통해 이어지는지 확인하는것이 중요하다.
저작자표시 (새창열림)

'코딩테스트 > Python' 카테고리의 다른 글

GCD(Great Common Divisior), LCM(Least Common Multiple)  (2) 2023.03.24
[Baekjoon] 1992. 쿼드트리  (0) 2023.01.30
[Programmers] Level 3. 경주로 건설  (1) 2023.01.20
[Baekjoon] 1012. 유기농 배추  (1) 2023.01.20
[Programmers] Level 3. 합승 택시 요금  (0) 2023.01.19
'코딩테스트/Python' 카테고리의 다른 글
  • GCD(Great Common Divisior), LCM(Least Common Multiple)
  • [Baekjoon] 1992. 쿼드트리
  • [Programmers] Level 3. 경주로 건설
  • [Baekjoon] 1012. 유기농 배추
swwho
swwho
일상을 데이터화하다
  • swwho
    하루한장
    swwho
  • 전체
    오늘
    어제
    • 분류 전체보기 (189)
      • ML_DL (40)
        • MUJAKJUNG (무작정 시리즈) (19)
        • 딥러닝 공부하기 (21)
      • 데이터사이언스 (1)
        • EDA (1)
        • 데이터과학을 위한 통계 (0)
      • 데이터엔지니어링 (2)
      • 논문리뷰 (2)
        • Computer Vision (2)
      • Python 활용하기 (12)
      • 코딩테스트 (127)
        • Python (109)
        • MySQL (14)
      • Git (3)
      • MySQL 활용하기 (0)
      • 일상 이야기 (1)
  • 블로그 메뉴

    • 홈
    • 태그
  • 최근 글

  • 250x250
  • hELLO· Designed By정상우.v4.10.3
swwho
[Baekjoon] 1389. 케빈 베이컨의 6단계 법칙
상단으로

티스토리툴바