algorithm/baekjoon

[BOJ] 5557 1학년 (python)

올빼밋. 2021. 9. 29. 16:05
728x90

# 출처 : https://www.acmicpc.net/problem/5557

 

5557번: 1학년

상근이가 1학년 때, 덧셈, 뺄셈을 매우 좋아했다. 상근이는 숫자가 줄 지어있는 것을 보기만 하면, 마지막 두 숫자 사이에 '='을 넣고, 나머지 숫자 사이에는 '+' 또는 '-'를 넣어 등식을 만들며 놀

www.acmicpc.net


# 풀이

 


# 코드

N=int(input())
arr=list(map(int, input().split()))

MIN=0; MAX=20
dp=[[-1]*(MAX+1) for _ in range(N)] # N-1행 21열 생성

def check(depth, total):
    print(depth)
    if total<MIN or total>MAX: return 0 #범위를 벗어난 곳은 0을 반환
    
    if dp[depth][total]!=-1: #이미 해당 값이 정답이 될 수 있는 행렬이면,
        return dp[depth][total] #해당 위치의 값을 반환하여 더해질 수 있게 만듦

    if depth==N-1: #깊이가 끝까지 왔다면,
        if total==arr[N-1]: #와중에 정답이랑 일치하면,
            return 1 #이건 되는 값이라고 알려주기
        return 0 #정답이랑 일치하지 않으면, 안된다고 알려주기

    dp[depth][total]=0 #들렸다고 표기, 만약 해당 값이 정답이 될 수 있는 행렬이면, 아래에서 값이 변함
    dp[depth][total]+=check(depth+1, total+arr[depth]) #최종 깊이까지 더하기
    dp[depth][total]+=check(depth+1, total-arr[depth]) #최종 깊이까지 빼기
    return dp[depth][total]

print(check(1, arr[0]))
728x90