[BOJ / C++] 세 수의 합 (이분탐색)

2025. 7. 27. 17:36·코딩테스트/BOJ

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

 

1. 코드

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

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

    int n;
    cin >> n;

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

    vector<int> two;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            two.push_back(arr[i] + arr[j]);
        }
    }
    sort(two.begin(), two.end());

    for (int i = n-1; i >= 0; i--) {
        for (int j = 0; j <= i; j++) {
            if (binary_search(two.begin(), two.end(), arr[i] - arr[j])) {
                cout << arr[i];
                return 0;
            }
        }
    }
}

 

 

2. 분석

만약 i, j, k를 다 더하고 이분탐색으로 찾으면 O(n^3lgn)이 되어 시간초과가 된다. 따라서 O(n^2lgn) 까지 시간복잡도를 낮춰야하는데 2개의 합을 미리 two 배열에 저장해두면 된다. 즉 arr[x] + arr[y] + arr[z] == arr[k]를 찾는 것이 아니라, arr[x] + arr[y] == arr[k] - arr[z]를 찾는 방식이다. 배열에서 선택은 중복돼도 상관없으므로 신경쓰지 않는다.

 

 

3. 시간복잡도

마지막 코드 부분에서 이중 for 문에 binary_search이므로 O(n^2lgn)이다. n = 10^3이므로 10^7 < 10^8 으로 시간제한 1초 내에 통과 가능하다.

 

 

 

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

[BOJ / C++] 랜선 자르기 (이분탐색, Parametric Search)  (0) 2025.07.28
[BOJ / C++] 2×n 타일링 2 (다이나믹 프로그래밍)  (0) 2025.07.28
[BOJ / C++] 좌표 압축 (이분탐색)  (0) 2025.07.26
[BOJ / C++] 숫자 카드 2 (이분탐색)  (0) 2025.07.26
[BOJ / C++] 정수 삼각형 (다이나믹 프로그래밍)  (0) 2025.07.26
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 랜선 자르기 (이분탐색, Parametric Search)
  • [BOJ / C++] 2×n 타일링 2 (다이나믹 프로그래밍)
  • [BOJ / C++] 좌표 압축 (이분탐색)
  • [BOJ / C++] 숫자 카드 2 (이분탐색)
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++] 세 수의 합 (이분탐색)
상단으로

티스토리툴바