[BOJ / C++] 랜선 자르기 (이분탐색, Parametric Search)

2025. 7. 28. 21:07·코딩테스트/BOJ

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

 

1. 코드

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

using ll = long long;

bool solve(vector<int>& arr, int k, int n, ll x) {
    ll cur = 0;
    for (int i = 0; i < k; i++) cur += arr[i] / x;
    return cur >= n;
}

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

    int k, n;
    cin >> k >> n;

    vector<int> arr(k);
    for (int i = 0; i < k; i++) cin >> arr[i];

    ll st = 1;
    ll en = 0x7fffffff; // 2^31-1
    while (st <= en) {
        ll mid = (st+en)/2;
        if (solve(arr, k, n, mid)) st = mid+1;
        else en = mid-1;
    }
    cout << en;
}

 

 

2. 시간복잡도

k = 10,000, n = 1,000,000이다. Parametric Search를 하는데 탐색 구간은 [1, 2^31-1]이고 이진탐색에 lgn이 소요되므로 lg2^31 = 31이다. 한번의 이진탐색당 k번 loop를 반복하니 시간복잡도는 O(k)이다.

따라서 전체 시간복잡도는 O(k * lg2^31)이고 310,000 < 10^8 이므로 시간제한 1초 내에 통과 가능하다.

 

 

3. 분석

* Parametric Search란?

: 조건을 만족하는 최소/최댓값을 구하는 문제(최적화 문제)를 결정문제로 변환해 이분탐색을 수행하는 방법이다.

 

이 문제에서는 이렇게 적용된다.

(최적화 문제) N개를 만들 수 있는 랜선의 최대 길이

(결정 문제) 랜선의 길이가 r일 때 랜선이 N개 이상인가 아닌가?

 

이렇게 (최적화 문제)를 (결정문제)로 바꾸고 길이의 전체 범위 [1, 2^31-1]에서 랜선 길이가 최대가 되는 upper_bound 지점을 이분탐색으로 찾아내면 된다.

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

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

티스토리툴바