코딩테스트[파이썬]/알고리즘 문제풀이 입문

[DFS활용] - 양팔저울

softmoca__ 2024. 2. 11. 16:33
목차

양팔 저울

 

 

무게가 서로 다른 K개의 추와 빈 그릇이 있다. 모든 추의 무게는 정수이고, 그릇의 무게는 0 으로 간주한다. 양팔저울을 한 번만 이용하여 원하는 물의 무게를 그릇에 담고자 한다.
주어진 모든 추 무게의 합을 S라 하자. 예를 들어, 추가 3개이고, 각 추의 무게가 {1, 2, 6}이 면, S=9이고, 양팔저울을 한 번만 이용하여 1부터 S사이에 대응되는 모든 무게의 물을 다음과 같이 그릇에 담을 수 있다. X는 그릇에 담는 물의 무게이고,
은 그릇을 나타낸다.

 

만약 추의 무게가 {1, 5, 7}이면 S=13이고, 그릇에 담을 수 있는 물의 무게는 {1, 2, 3, 4, 5, 6, 7, 8, 11, 12, 13}이고, 1부터 S사이에서 무게에서 9와 10에 대응하는 무게의 물을 담을 수 없다.
K(3<=K<=13)개의 추 무게가 주어지면, 1부터 S사이의 정수 중 측정이 불가능한 물의 무게는 몇 가지가 있는 지 출력하는 프로그램을 작성하세요.

 

입력설명
첫 번째 줄에 자연수 K(3<=K<=13)이 주어집니다.
두 번째 줄에 K개의 각 추의 무게가 공백을 사이에 두고 주어집니다. 각 추의 무게는 1부터 200,000까지이다.

출력설명
첫 번째 측정이 불가능한 가지수를 출력하세요.

 

입력예제 1

3
1 5 7

출력예제 1

2

 

나의코드

def DFS(L,res):
    if L==k:
        if res>0:
            ch[res]=1
    else:
        DFS(L+1,res-arr[L])
        DFS(L+1,res)
        DFS(L+1,res+arr[L])
    

k=int(input())
arr=list(map(int,input().split()))
S=sum(arr)
ch=[0]*(S+1)

DFS(0,0)
print(S-sum(ch))

위와 같이 입력받은 값을 1. 뺴기 2.그대로 두기 3. 더하기 총 3갈래로 탐색을 진행하였다.

 

정답코드

import sys
sys.stdin=open("input.txt", "r")
def DFS(L, sum):
    global res
    if L==n:
        if 0<sum<=s:
            res.add(sum)
    else:
        DFS(L+1, sum+G[L])
        DFS(L+1, sum-G[L])
        DFS(L+1, sum)

if __name__=="__main__":
    n=int(input())
    G=list(map(int, input().split()))
    s=sum(G)
    res=set()
    DFS(0, 0)
    print(s-len(res))

 

체크 배열을 사용한 나와 달리 집합을 사용하였따.