[BOJ / C++] 구간 합 구하기 4 (다이나믹 프로그래밍, prefix sum)

2025. 7. 22. 17:24·코딩테스트/BOJ

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

 

1. 코드

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

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

    int n, m; 
    cin >> n >> m;

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

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

    while (m--) {
        int i, j;
        cin >> i >> j;
        cout << d[j] - d[i-1] << '\n';
    }
}

 

 

2. 분석

1. dp 테이블 정의:

i번째까지 수열의 누적합을 저장한다.

 

2. 점화식:

d[i] = d[i-1] + arr[i];

 

이러한 방식을 prefix sum이라고 한다. prefix sum을 통해 구간 합을 계산하면 dp 테이블 계산에 O(n) 구간합 계산에 O(1)이 걸려 시간복잡도 O(n)에 구간합을 구할 수 있다. 구간합은 d[i] - d[j-1]로 계산 가능하다.

 

3. 시간복잡도

시간복잡도는 단순히 생각하면 O(nm)인데 10^5 * 10^5 = 10^10 > 10^8 이므로 시간초과 판정이 나게된다. 따라서 구간 합을 계산하는 것의 시간복잡도를 떨어뜨려야하고 위 방법처럼 prefix sum을 이용하면 시간복잡도 O(n)에 계산이 가능하다. 10^5 < 10^8 이므로 시간제한 1초 이내에 통과 가능하다. 

 

 

 

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

[BOJ / C++] 빙산 (BFS)  (0) 2025.07.23
[BOJ / C++] 동전 0 (그리디)  (0) 2025.07.22
[BOJ / C++] 2×n 타일링 (다이나믹 프로그래밍)  (0) 2025.07.22
[BOJ / C++] RGB 거리 (다이나믹 프로그래밍)  (0) 2025.07.22
[BOJ / C++] 1, 2, 3 더하기 (다이나믹 프로그래밍)  (0) 2025.07.21
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 빙산 (BFS)
  • [BOJ / C++] 동전 0 (그리디)
  • [BOJ / C++] 2×n 타일링 (다이나믹 프로그래밍)
  • [BOJ / C++] RGB 거리 (다이나믹 프로그래밍)
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) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

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

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 구간 합 구하기 4 (다이나믹 프로그래밍, prefix sum)
상단으로

티스토리툴바