[BOJ / C++] 과자 나눠주기 (이분탐색, Parametric Search)

2025. 7. 29. 16:40·코딩테스트/BOJ

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

 

1. 코드

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

using ll = long long;

bool possible(vector<int>& snack, int len, int m) {
    ll num = 0;
    for (int i = 0; i < snack.size(); i++) {
        num += snack[i] / len;
    }
    return num >= m;
}

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

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

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

    ll st = 0;
    ll en = 0x7fffffff;
    while (st <= en) {
        ll mid = (st + en) / 2;
        
        if (mid == 0) {
            cout << 0;
            return 0;
        }

        if (possible(snack, mid, m)) st = mid+1;
        else en = mid-1;
    }

    cout << en; 
}

 

 

2. 시간복잡도

Parametric Search를 사용해야한다. 과자의 길이 전 범위에서 이분탐색을 진행한다. len = 1,000,000,000이므로 lg(len) = 30이고, 나눠지는 갯수가 몇개인지 세는데 O(n)이 걸리므로 n = 1,000,000이고, O(nlg(len)) = 1,000,000 * 30 = 30,000,000 < 10^8 이므로 시간제한 1초 안에 통과 가능하다.

 

 

3. 분석

Parametric Search 문제이다. 

while (st <= en) {
    ll mid = (st + en) / 2;
    if (possible(snack, mid, m)) st = mid+1;
    else en = mid-1;
}

 

이렇게 하면 st==en까지 possible의 범위의 upper bound에 오고 마지막에 st = mid + 1이 되면서 en이 마지막 possible이 된다. 

 

문제 조건에서 모든 조카에게 같은 길이의 막대과자를 나눠줄 수 없으면 0을 출력하라는 조건이 있는데 해당 부분 처리를 위해 mid == 0 이 면 0을 출력하고 종료되게했다. 이런 처리를 하지 않으면 possible 함수에서 zero divide로 인한 런타임에러가 발생한다.

 

 

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

[BOJ / C++] 부분합 (투포인터)  (0) 2025.07.30
[BOJ / C++] 수 고르기 (투포인터)  (0) 2025.07.30
[BOJ / C++] 차집합 (이분탐색)  (0) 2025.07.29
[BOJ / C++] 숫자 카드 (이분탐색)  (0) 2025.07.28
[BOJ / C++] 랜선 자르기 (이분탐색, Parametric Search)  (0) 2025.07.28
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 부분합 (투포인터)
  • [BOJ / C++] 수 고르기 (투포인터)
  • [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++] 과자 나눠주기 (이분탐색, Parametric Search)
상단으로

티스토리툴바