본문 바로가기
Sketch (Programming Language)/Python

Baekjoon Training #2579

by 생각하는 이상훈 2023. 1. 31.
728x90

#2579 계단 오르기

#계단 수 입력
n = int(input())

#계단 세팅
stair = [0]*301
for i in range(n):
    stair[i] = int(input())

#점수를 담아둘 리스트
point_set = [0]*301
#1칸인 경우
point_set[0] = stair[0]
#2칸인 경우
point_set[1] = stair[0]+stair[1]
#3칸인 경우
point_set[2] = max(stair[0]+stair[2], stair[1]+stair[2])

#4칸이상인 경우
for i in range(3, n):
#n-3칸까지의 최대값과 최종 두계단의 합과 n-2칸까지의 합과 최종 계단 둘중 큰 값을 point_set[n]에 저장
    point_set[i] = max(point_set[i-3] + stair[i-1] + stair[i], point_set[i-2]+stair[i])

#인덱스로 호출하므로 n개의 계단이면 n-1을 출력
print(point_set[n-1])

Dynamic programming의 3번째 문제였는데 단순하게 재귀 호출로 하면 시간초과가 날 것이 너무 뻔했고 실제로도 그랬다. 따라서 경우를 따져보며 규칙을 찾는 것이 중요했다. 계단이 3칸인 경우 까지는 경우의 수가 그리 많지 않았고 그 이후부터는 이전에 구해둔 점수들의 합의 최대값을 이용하면 보다 단순하게 두가지 경우만 조사하면 된다는 사실을 알게 되었다.


728x90

'Sketch (Programming Language) > Python' 카테고리의 다른 글

Baekjoon Training #1193  (0) 2023.02.04
Baekjoon Training #10844  (3) 2023.02.02
Baekjoon Training #9461  (2) 2023.01.29
Baekjoon Training #1446  (0) 2023.01.27
Baekjoon Training #1620  (0) 2023.01.26