[프로그래머스 / C++] 징검다리

Seulguo·2022년 7월 13일
0

Algorithm

목록 보기
63/185
post-thumbnail
post-custom-banner

🐣 문제

링크 : https://school.programmers.co.kr/learn/courses/30/lessons/43236


🐥 코드

#include <string>
#include <vector>
#include <algorithm>

using namespace std;

int solution(int distance, vector<int> rocks, int n) {
    int answer = 0;
    int left = 0, right = distance;
    sort(rocks.begin(), rocks.end());
 
    while(left <= right) {
        int mid = (left + right) / 2;
        int prev = 0, cnt = 0;
 
        for(int i = 0; i < rocks.size(); i++) {
            if(rocks[i] - prev < mid)   cnt++;
            else prev = rocks[i];
        }
        if(distance - prev < mid)  cnt++;
 
        if(cnt <= n) {  
            answer = max(mid, answer);
            left = mid + 1;
        }
        else right = mid - 1;
    }
    return answer;
}
post-custom-banner

0개의 댓글