2251번 : 물통 - Python

FriOct·2023년 5월 25일
0

PS

목록 보기
102/108

문제

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

풀이

각 a, b, c물통에 대하여 물을 옮길 수 있는 모든 경우의수를 고려하면 된다. 각 경우를 고려하다가 a물통에 물이 비어있는 경우 c물통에 있는 물의 양을 저장하면 된다.

추가추가 : 예를 들어 a -> b로 물을 옮길때

w=min(a,maxbb)w = min(a,maxb - b)
a=aw,b=b+wa = a-w, b = b+w
로 구할 수도 있다.

코드

from sys import stdin
from collections import deque

input= stdin.readline

a, b, c = map(int,input().split())

s = "0 "+"0 " + str(c) #처음 시작하는 c물통에만 물이 차있는 경우를 저장

arr = list() #조건에 맞을때 c에 있는 물의 양을 저장하는 list
visited= {s} #전에 만들어 졌는지 판단하는 visited
queue = deque()
queue.append(s)

def bfs(ma,mb,mc):
    

    while queue:
        #a, b, c에 각 물통에 들어있는 물의 양을 저장
        a, b, c = map(int,queue.popleft().split())

        #a에 들어있는 물의 양이 0이면 그때의 c를 arr에 추가
        if a==0:
            arr.append(c)

        #a물통에서 옮기는 경우
        if a!=0:
            #a에서 b로 옮기는 경우 
            if a+b<=mb:
                s = "0 " + str(a+b) + " " + str(c)
            else:
                s = str(a+b-mb) + " " + str(mb) + " " + str(c)
            
            if not (s in visited):
                visited.add(s)
                queue.append(s)

            #a에서 c로 옮기는 경우
            if a+c<=mc:
                s = "0 " + str(b) + " " + str(a+c)
            else:
                s = str(a+c-mc) + " " + str(b) + " " + str(mc)
            
            if not (s in visited):
                visited.add(s)
                queue.append(s)

        #b물통에서 옮기는 경우
        if b!=0:
            #b에서 a로 옮기는 경우
            if b+a<=ma:
                s = str(b+a) + " " + "0 " + str(c)
            else:
                s = str(ma) + " " + str(b+a-ma) + " " + str(c)
            
            if not (s in visited):
                visited.add(s)
                queue.append(s)

            #b에서 c로 옮기는 경우
            if b+c<=mc:
                s = str(a) + " " + "0 " + str(b+c)
            else:
                s = str(a) + " " + str(b+c-mc) + " " + str(mc)
            
            if not (s in visited):
                visited.add(s)
                queue.append(s)

        #c물통에서 옮기는 경우
        if c!=0:
            #c에서 a로 옮기는 경우
            if c+a<=ma:
                s = str(c+a) + " " + str(b) + " 0" 
            else:
                s = str(ma) + " " + str(b) + " " + str(c+a-ma)
            
            if not (s in visited):
                visited.add(s)
                queue.append(s)

            #c에서 b로 옮기는 경우
            if c+b<=mb:
                s = str(a) + " " + str(c+b) + " 0"
            else:
                s = str(a) + " " + str(mb) + " " + str(c+b-mb)
            
            if not (s in visited):
                visited.add(s)
                queue.append(s)


bfs(a,b,c)

arr.sort() #저장된 값을 오름차순으로 정렬

print(*arr)

참고

다른 코드

profile
꿈 많은 개발자

0개의 댓글