Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- 프로그래머스
- 웹어플리케이션 서버
- MSA
- JPA
- 백준 16235
- java 기술면접
- 백준
- spring cloud
- 백준 15685
- 백준 17626
- Spring
- 백준 16719
- re.split
- Spring Boot
- springboot
- 백준 파이썬
- 백준 17779
- 파이썬
- 프로래머스
- Coroutine
- 백준 19238
- spring oauth
- spring security
- Kotlin
- JVM
- MySQL
- sql 기술면접
- java
- with recursive
- 백준 16236
Archives
- Today
- Total
시작이 반
[백준] 1932번(python 파이썬) 본문
SMALL
트리형태..
이런형태의 리스트로 만들 수 있다.
triangle[i][j] j i |
0 | 1 | 2 | 3 | 4 |
0 | 7 | ||||
1 | 3 | 8 | |||
2 | 8 | 1 | 0 | ||
3 | 2 | 7 | 4 | 4 | |
4 | 4 | 5 | 2 | 6 | 5 |
dp[i][j] j i |
0 | 1 | 2 | 3 | 4 |
0 | triangle[i][j] | ||||
1 | dp[i-1][ j ] + triangle[ i ][ j ] | dp[i-1][ j ] + triangle[ i ][ j ] | |||
2 | dp[i-1][ j ] + triangle[ i ][ j ] | MAX(dp[i-1][j-1], dp[i-1][ j ]) + triangle[ i ][ j ] |
dp[i-1][ j ] + triangle[ i ][ j ] | ||
3 | dp[i-1][ j ] + triangle[ i ][ j ] | MAX(dp[i-1][j-1], dp[i-1][ j ]) + triangle[ i ][ j ] |
MAX(dp[i-1][j-1], dp[i-1][ j ]) + triangle[ i ][ j ] |
dp[i-1][ j ] + triangle[ i ][ j ] | |
4 | dp[i-1][ j ] + triangle[ i ][ j ] | MAX(dp[i-1][j-1], dp[i-1][ j ]) + triangle[ i ][ j ] |
MAX(dp[i-1][j-1], dp[i-1][ j ]) + triangle[ i ][ j ] |
MAX(dp[i-1][j-1], dp[i-1][ j ]) + triangle[ i ][ j ] |
dp[i-1][ j ] + triangle[ i ][ j ] |
깊이로 설명하면
1. 현재 깊이의 맨 왼쪽 값 : 이전깊이의 맨왼쪽 값 + 자기자신
2. 현재 깊이의 맨 오른쪽 값 : [이전깊이][맨오른쪽 값] + 자기자신
3. 그외 : MAX([이전 깊이][현재 index -1] , [이전 깊이][현재 index]) + 자기 자신
n = int(input())
triangle = [list(map(int, input().split())) for _ in range(n)]
dp = list()
for i in range(n):
dp.append([0]*(i+1))
def int_triangle():
global dp
for i in range(n):
for j in range(len(dp[i])):
if i == 0:
dp[i][j] = triangle[i][j]
else:
if j == 0 :
dp[i][j] = dp[i - 1][j] + triangle[i][j]
elif j == len(dp[i])-1:
dp[i][j] = dp[i - 1][j - 1] + triangle[i][j]
else:
dp[i][j] = max(dp[i - 1][j - 1], dp[i - 1][j]) + triangle[i][j]
return max(dp[n-1])
print(int_triangle())
LIST
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 1463번(python 파이썬) (0) | 2021.02.08 |
---|---|
[백준] 2579번(python 파이썬) (0) | 2021.02.08 |
[백준] 9461번(python 파이썬) (0) | 2021.02.06 |
[백준] 9461번(python 파이썬) (0) | 2021.02.06 |
[백준] 20208번(python 파이썬) (0) | 2021.02.04 |