Scribbling

[Programmers] 징검다리 본문

Computer Science/Algorithms & Data Structures

[Programmers] 징검다리

focalpoint 2024. 6. 27. 13:17

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. Python

def solution(distance, rocks, n):
    ret = 1
    rocks.sort()
    rocks.append(distance)
    left, right = 1, distance
    while left <= right:
        mid = (left + right) // 2
        cnt = 0
        prv = 0
        for cur in rocks:
            if cur - prv < mid:
                cnt += 1
            else:
                prv = cur
        if cnt <= n:
            ret = max(ret, mid)
            left = mid + 1
        else:
            right = mid - 1
    return ret

 

2. C++

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

using namespace std;

int solution(int distance, vector<int> rocks, int n) {
    int ret = 1;
	sort(rocks.begin(), rocks.end());
	rocks.push_back(distance);
	int left = 1, right = distance;
	while (left <= right) {
		int mid = (left + right) / 2;
		int cnt = 0, prv = 0;
		for (int cur : rocks) {
			if (cur - prv < mid) cnt++;
			else prv = cur;
		}
		if (cnt <= n) {
			ret = max(ret, mid);
			left = mid + 1;
		} else {
			right = mid - 1;
		}
	}
	return ret;
}

 

 

'Computer Science > Algorithms & Data Structures' 카테고리의 다른 글

[Programmers] 가장 먼 노드  (0) 2024.06.28
[Programmers] 입국심사  (0) 2024.06.27
[Programmers] 여행경로  (0) 2024.06.24
[Programmers] 아이템 줍기  (0) 2024.06.21
[Programmers] 단어 변환  (0) 2024.06.20