[BOJ / C++] 수들의 합 2 (투포인터)

2025. 7. 31. 00:32·코딩테스트/BOJ

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

 

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);
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
    }

    int en = 0;
    int cnt = 0;
    int sum = arr[0];
    for (int st = 0; st < n; st++) {
        while (en < n && sum < m) {
            en++;
            sum += arr[en];
        }
        if (en == n) break;
        if (sum == m) cnt++;
        sum -= arr[st];
    }
    cout << cnt;
}

 

 

2. 시간복잡도

st와 en이 최대 n 번이므로 시간복잡도는 O(2n)이다. 만약 brute force 식으로 3중 for 문을 돌면 n = 10^4 이므로 n^3 = 10^12 > 10^7으로 0.5초 제한 시간초과가 발생한다. prefix sum dp테이블을 미리 만들고 2중 for 문으로 해도 n^2 = 10^8 > 10^7으로 시간초과 위협이 있다.

따라서 투포인터를 이용해 O(n)에 해결하는 것이 좋다. 

 

 

3. 분석

sum > m이 되어버리면 더이상 sum == m일 가능성이 없는 것에 주목해야한다. sum < m일 때까지만 en을 증가시키면서 sum을 계산하고 sum == m인 경우에만 cnt를 증가시키는 방식으로 투포인터를 활용한다.

 

 

 

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

[BOJ / C++] 문제 추천 시스템 Version 2 (이진검색트리)  (0) 2025.08.02
[BOJ / C++] 문제 추천 시스템 Version 1 (이진검색트리)  (0) 2025.08.01
[BOJ / C++] 부분합 (투포인터)  (0) 2025.07.30
[BOJ / C++] 수 고르기 (투포인터)  (0) 2025.07.30
[BOJ / C++] 과자 나눠주기 (이분탐색, Parametric Search)  (0) 2025.07.29
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 문제 추천 시스템 Version 2 (이진검색트리)
  • [BOJ / C++] 문제 추천 시스템 Version 1 (이진검색트리)
  • [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) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

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

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 수들의 합 2 (투포인터)
상단으로

티스토리툴바