https://www.acmicpc.net/problem/25824
문제
선생님 1명과 학생 12명이 있다. 학생에게 1번부터 12번까지 번호가 부여된다. 학생들은 두 명씩 하나의 친구 집단을 이룬다. 1번 학생부터 번호순으로 두 명씩 하나의 친구 집단에 포함된다. 즉, 친구 집단 1은 {학생 1번, 학생 2번}, 친구 집단 2는 {학생 3번, 학생 4번}, ... , 친구 집단 6은 {학생 11번, 학생 12번}으로 구성된다.
선생님은 긴급 메시지를 12명 학생 모두에게 최대한 빠르게 전달하려고 한다. 선생님은 긴급 메시지를 친구 집단 1에 전달한다. 선생님으로부터 메시지를 전달받은 1번 또는 2번 학생은 같은 친구 집단에 있는 다른 친구 2번 또는 1번 학생에게 메시지를 전달한다. 메시지를 전달받은 1번 학생 또는 2번 학생은 친구 집단 2에 메시지를 전달한다. 메시지를 받은 친구는 앞에서 언급된 내용과 같은 방식으로 친구 집단 내에 다른 친구에게 메시지를 전달하고 메시지를 전달받은 친구는 친구 집단 3에 메시지를 전달한다. 친구 집단 4, 친구 집단 5, 친구 집단 6 순서대로 메시지를 전달하고 12명의 학생이 모두 메시지를 받으면 선생님의 메시지 전달이 완료된다. 선생님은 첫 번째 학생에게 메시지를 즉시 전달하기 때문에 첫 번째 학생이 메시지를 받는 데 걸리는 시간은 0으로 생각한다. 12명의 학생이 다른 친구에게 메시지를 전달하는 데 걸리는 시간이 주어지면, 친구 집단 1부터 친구 집단 6 순서대로 12명의 친구에게 메시지를 전달하는데 걸리는 최소 시간을 출력하자.
입력
첫 번째 줄부터 열두 개의 줄에 걸쳐 메시지를 전달하는 데 걸리는 시간이 주어진다. i번째 줄의 j번째 숫자는 학생 i가 학생 j에게 메시지를 전달하는 데 걸리는 시간을 나타낸다.
출력
첫 번째 줄에 친구 집단 1부터 친구 집단 6 순서대로 12명의 친구에게 메시지를 전달하는데 걸리는 최소 시간을 출력한다.
풀이
Code
import sys
input = sys.stdin.readline
# 1. 백트래킹 함수 정의
def backtracking(student, group, time) :
global ans
# 1-1. 같은 그룹 내 다른 친구에게 전달
another_student = student + 1 if student % 2 == 0 else student - 1
time += graph[student][another_student]
# 1-2. 종료 조건 설정
if group == 6 :
ans = min(ans, time)
return
# 1-3. 다음 그룹의 친구에게 전달
backtracking(group * 2, group + 1, time + graph[another_student][group * 2])
backtracking(group * 2 + 1, group + 1, time + graph[another_student][group * 2 + 1])
graph = [list(map(int, input().split(' '))) for _ in range(12)]
ans = float('inf')
# 2. 백트래킹 실행
backtracking(0, 1, 0)
backtracking(1, 1, 0)
# 3. 결과 출력
print(ans)
'Coding Test > Baekjoon' 카테고리의 다른 글
[Python/BOJ] 8972. 미친 아두이노 (0) | 2023.09.04 |
---|---|
[Python/BOJ] 1043. 거짓말 (0) | 2023.09.03 |
[Python/BOJ] 5972. 택배 배송 (1) | 2023.09.03 |
[Python/BOJ] 3649. 로봇 프로젝트 (0) | 2023.09.03 |
[Python/BOJ] 1484. 다이어트 (0) | 2023.09.02 |