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
- Widget
- 코테연습
- 코테
- 동적계획법
- c++
- 언리얼4
- UE5
- blueprint
- DP
- Unity
- 알고리즘
- AIPerception
- 다이나믹프로그래밍
- EffectiveC++
- 프로그래머스
- UnReal
- server
- dfs
- 재귀
- Stimuli
- UMG
- 코딩테스트
- HTTP
- UE4
- uproperty
- 나나이트
- 유니티
- 문자열
- 언리얼
- ue4macro
Archives
- Today
- Total
공부 기록
[프로그래머스] level 3 - 정수 삼각형 (C++) 본문
문제 설명
위와 같은 삼각형의 꼭대기에서 바닥까지 이어지는 경로 중, 거쳐간 숫자의 합이 가장 큰 경우를 찾아보려고 합니다. 아래 칸으로 이동할 때는 대각선 방향으로 한 칸 오른쪽 또는 왼쪽으로만 이동 가능합니다. 예를 들어 3에서는 그 아래칸의 8 또는 1로만 이동이 가능합니다. 삼각형의 정보가 담긴 배열 triangle이 매개변수로 주어질 때, 거쳐간 숫자의 최댓값을 return 하도록 solution 함수를 완성하세요.
- 삼각형의 높이는 1 이상 500 이하입니다.
- 삼각형을 이루고 있는 숫자는 0 이상 9,999 이하의 정수입니다.
문제 풀이
dp 유형의 문제. 처음에 dp배열을 vector로 선언했다가 계속 시간초과가 났는데 2차원 배열로 바꿨더니 간단하게 통과했다.
vector는 인덱싱을 지원하지 않기 때문에 각 원소에 접근할때 포인터를 이용(시간이 일정하지 않음)하므로 배열에서 인덱스로 접근(인덱스마다 시간 일정)하는 것 보다 시간이 느리다고 한다. 참고하자! (물론 이중연결리스트보단 훨씬 빠르다)
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
int dp[500][500];
vector<vector<int>> nums;
int getDP(int row, int col)
{
if (row == nums.size() || dp[row][col] != 0) return dp[row][col];
dp[row][col] = nums[row][col] + max(getDP(row+1, col), getDP(row+1, col+1));
return dp[row][col];
}
int solution(vector<vector<int>> triangle) {
int answer = 0;
int n = triangle.size();
nums = triangle;
for (int i=0; i<n; i++)
{
dp[n-1][i] = triangle[n-1][i];
}
answer = getDP(0,0);
return answer;
}
+) vector와 array 차이점 참고 블로그
'Algorithm > Programmers' 카테고리의 다른 글
[프로그래머스] level 3 - 입국 심사 (C++) (0) | 2022.04.11 |
---|---|
[프로그래머스] level 3 - 기지국 설치 (C++) (0) | 2022.03.22 |
[프로그래머스] level 3 - 단어 변환 (C++) (0) | 2022.03.21 |
[프로그래머스] level 3 - 스타 수열 (C++) (0) | 2022.03.15 |
[프로그래머스] level 2 - 스킬트리 (C++) (0) | 2022.03.11 |
Comments