[Baekjoon] 돌 그룹

Updated:

문제

오늘 강호는 돌을 이용해 재미있는 게임을 하려고 한다. 먼저, 돌은 세 개의 그룹으로 나누어져 있으며 각각의 그룹에는 돌이 A, B, C개가 있다. 강호는 모든 그룹에 있는 돌의 개수를 같게 만들려고 한다.

강호는 돌을 단계별로 움직이며, 각 단계는 다음과 같이 이루어져 있다.

크기가 같지 않은 두 그룹을 고른다. 그 다음, 돌의 개수가 작은 쪽을 X, 큰 쪽을 Y라고 정한다. 그 다음, X에 있는 돌의 개수를 X+X개로, Y에 있는 돌의 개수를 Y-X개로 만든다.

A, B, C가 주어졌을 때, 강호가 돌을 같은 개수로 만들 수 있으면 1을, 아니면 0을 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 A, B, C가 주어진다. (1 ≤ A, B, C ≤ 500)

출력

돌을 같은 개수로 만들 수 있으면 1을, 아니면 0을 출력한다.

예제

Example 1:

Input: 
10 15 35
Output: 
1

Example 2:

Input:
1 1 2
Output:
0

조건

시간 제한 : 2초

메모리 제한 : 512 MB

풀이과정

풀이 1

BFS로 해결하였다. 우선 비교할 때 비교대상이 같은 경우는 한쪽이 0이 되므로 같아질 수 없다고 생각했고 비교대상이 한쪽이 한쪽의 2배라면 X+X, Y-X 연산을 해도 결과가 같기 때문에 위 두 경우를 제외하며 진행하였다.

visited같은 경우에는 처음에는 리스트로 받아서 했는데 시간 초과가 나서 defaultdict(bool)을 활용하니 잘 되었다. 앞으로 defaultdict을 많이 활용해야겠다는 생각이 든다.

from collections import deque, defaultdict
import sys
a, b, c = map(int, input().split())

q = deque()
q.append([a, b, c])
visited = defaultdict(bool)

while q:
    na, nb, nc = q.popleft()
    if na == nb == nc:
        print(1)
        sys.exit()

    sub = sorted([na,nb,nc])
    # 0, 1
    if sub[0] == sub[1] or 2*sub[0] == sub[1]:
        pass
    else:
        n_sub = sorted([2*sub[0], sub[1]-sub[0],sub[2]])
        if not visited[tuple(n_sub)]:
            visited[tuple(n_sub)] = True
            q.append(n_sub)
    # 0, 2
    if sub[0] == sub[2] or 2*sub[0] == sub[2]:
        pass
    else:
        n_sub = sorted([2*sub[0], sub[2]-sub[0],sub[1]])

        if not visited[tuple(n_sub)]:
            visited[tuple(n_sub)] = True
            q.append(n_sub)
    # 1, 2
    if sub[1] == sub[2] or 2*sub[1] == sub[2]:
        pass
    else:
        n_sub = sorted([2*sub[1], sub[2]-sub[1],sub[0]])
        if not visited[tuple(n_sub)]:
            visited[tuple(n_sub)] = True
            q.append(n_sub)
print(0)

Leave a comment