티스토리 뷰

N = int(input())
dp = [0]+list(map(int,input().split()))
#합이 N인것의 조합, dp[i]에 최댓값 갱신
for i in range(N+1):
    for j in range(1,i+1):
        dp[i] = max(dp[i],dp[i-j]+dp[j])
print(dp[N])

인덱스를 맞추기위해 [0]앞에 더해줬다.

N을 만들 수 있는 조합을 찾기 위해 j 인덱스를 해당 인덱스i까지 증가시키면서 반복문을 돌린다.

여기서 점화식dp[i-j]+dp[j]가 쓰인다.

 

댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/11   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
글 보관함