[BOJ / C++] 정수 삼각형 (다이나믹 프로그래밍)

2025. 7. 26. 16:56·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/1932

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n;
    cin >> n;
    vector<vector<int>> board(n+1, vector<int>(n+1, 0));
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> board[i][j];
        }
    }

    vector<vector<int>> d(n+1, vector<int>(n+1, 0));
    d[1][1] = board[1][1];
    for (int i = 2; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            d[i][j] = board[i][j] + max(d[i-1][j], d[i-1][j-1]); 
        }
    }

    cout << *max_element(d[n].begin(), d[n].end());
}

 

 

2. 분석

1. dp 테이블:

d[i][j]: 해당 경로까지 왔을 때 최댓값

 

2. 점화식:

d[i][j] = board[i][j] + max(d[i-1][j], d[i-1][j-1]);

0행과 0열이 0으로 초기화되어있기 때문에 OOB 예외처리를 하지 않아도 된다.

 

 

3. 시간복잡도

dp테이블을 채우는데 n^2이 든다. O(n^2)인데 n = 500이므로 n^2 = 250,000 < 10^8 이므로 시간제한 2초내에 통과 가능하다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 좌표 압축 (이분탐색)  (0) 2025.07.26
[BOJ / C++] 숫자 카드 2 (이분탐색)  (0) 2025.07.26
[BOJ / C++] 수 찾기 (이분탐색)  (0) 2025.07.25
[BOJ / C++] 피보나치 함수 (다이나믹 프로그래밍)  (0) 2025.07.25
[BOJ / C++] Puyo Puyo (시뮬레이션, BFS)  (0) 2025.07.25
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 좌표 압축 (이분탐색)
  • [BOJ / C++] 숫자 카드 2 (이분탐색)
  • [BOJ / C++] 수 찾기 (이분탐색)
  • [BOJ / C++] 피보나치 함수 (다이나믹 프로그래밍)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (174) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (17) N
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (1) N
      • 코딩테스트 (96)
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13)
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 정수 삼각형 (다이나믹 프로그래밍)
상단으로

티스토리툴바