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
- nestjs
- 정렬
- typeORM
- Bull
- 자료구조
- Express
- react
- Python
- Queue
- 공룡게임
- 게임
- GIT
- class
- mongoose
- game
- Sequelize
- nodejs
- JavaScript
- OCR
- flask
- jest
- AWS
- MySQL
- dfs
- cookie
- Nest.js
- TypeScript
- Dinosaur
- MongoDB
Archives
- Today
- Total
포시코딩
[프로그래머스][DP] 정수 삼각형 - 복습필요 본문
728x90
문제
https://school.programmers.co.kr/learn/courses/30/lessons/43105
내 풀이
def solution(triangle):
# 거쳐간 숫자의 합
# 1 <= len(triangle) <= 500
# 각 원소는 0 이상 9999 이하
# 시작은 세 꼭지점 중 하나
# 꼭지점이 달라질 때가 문제
# 세가지 경우의 대한 합을 구하고 서로 비교?
# case 1. 그림에서 7이 시작인 경우
# t[0][0] -> t[1][0] vs t[1][1]
# F -> A vs B 라고 할 때
# A, B의 x는 1씩 커지고
# A, B의 y는 F[x][y]에 대해 y, y+1
# for x in range(len(triangle)):
# c1 += triangle[x][F]
# if triangle[x+1][F]
# case 2. 4가 시작인 경우
# x는 1씩 작아짐
# y는 ..
# 근데 숫자가 같은 경우 문제 발생
# 잠깐만, 각 인덱스 별로 현재 값을 유지하는게 아니라
# 맨 마지막 인덱스 배열에 모든 합이 되게끔 쭈우욱 내려오면 되는거 아닌가?
# 그래서 마지막 중 제일 높은 숫자 체크
# 이 경우 두 부모중 큰 숫자로 해야하네..
# 잠깐, 그럼 내가 처음에 생각한 각 꼭지점으로 돌려가며 구하는게 아닌가보네
# 이럴 경우 마지막 4, 5, 2, 6, 5에서 두번째 5에 합 30이 들어가게 됨
# 그럼 target인 자식의 노드가 이전 배열에서 자기 인덱스랑 자기 인덱스-1 노드를 비교해서 큰 수를 자기한테 더하면 되겠네?
# 맨 위 꼭지점은 생략하고 for문을 1부터 len(tri) 까지
for x in range(1, len(triangle)):
# 해당 배열의 인덱스 0은 항상 그대로 이전 배열 0을 더한다.
# 해당 배열의 마지막 인덱스는 항상 이전 배열의 마지막 요소 값을 더한다.
for y in range(len(triangle[x])):
if y == 0:
triangle[x][0] += triangle[x-1][0]
elif y == len(triangle[x])-1:
triangle[x][-1] += triangle[x-1][-1]
else:
if triangle[x-1][y] > triangle[x-1][y-1]:
triangle[x][y] += triangle[x-1][y]
else:
triangle[x][y] += triangle[x-1][y-1]
return max(triangle[-1])
처음에 문제 이해를 잘못해서 헤맸다.
DP를 쓰고 싶었지만 어떻게 각이 안보여 일단 생각나는대로 for문을 사용해 해결
다른 풀이
def solution(triangle):
memo = {}
answer = f(triangle, 0, 0, memo)
return answer
def f(triangle, i, j, memo):
if i == len(triangle)-1:
return triangle[i][j]
if (i,j) in memo:
return memo[(i,j)]
a = f(triangle, i+1, j, memo)
b = f(triangle, i+1, j+1, memo)
x = triangle[i][j] + max(a, b)
memo[(i,j)] = x
return x
문제 의도인 DP를 활용한 문제 풀이
재귀를 이용해 아래에서부터 합을 끌어올려 [0][0]에 합쳐진 값을 리턴하는 구조
좌표값에 대해 DP 알고리즘을 사용함으로써
(i, j)를 키 값으로 갖는 memo dict를 사용해 연산을 줄였다.
728x90
'자료구조알고리즘 > 문제풀이' 카테고리의 다른 글
[백준] 여러 줄의 입력값 받는 방법 (0) | 2023.04.17 |
---|---|
[백준] 한 줄로 된 리스트 입력값 받기 (0) | 2023.04.15 |
[프로그래머스][힙(Heap)] 더 맵게 (1) | 2023.04.13 |
[프로그래머스][Lv.0][재귀] 치킨 쿠폰 (0) | 2023.01.16 |
[프로그래머스][Lv.0] 등수 매기기 - 작성중 (0) | 2023.01.16 |