N개의 마구간이 수직선상에 있습니다. 각 마구간은 x1, x2, x3, ......, xN의 좌표를 가지며, 마 구간간에 좌표가 중복되는 일은 없습니다.
현수는 C마리의 말을 가지고 있는데, 이 말들은 서로 가까이 있는 것을 좋아하지 않습니다. 각 마구간에는 한 마리의 말만 넣을 수 있고, 가장 가까운 두 말의 거리가 최대가 되게 말을 마구간에 배치하고 싶습니다.
C마리의 말을 N개의 마구간에 배치했을 때 가장 가까운 두 말의 거리가 최대가 되는 그 최대 값을 출력하는 프로그램을 작성하세요.
[입력설명]
첫 줄에 자연수 N(3<=N<=200,000)과 C(2<=C<=N)이 공백을 사이에 두고 주어집니다. 둘째 줄에 마구간의 좌표 xi(0<=xi<=1,000,000,000)가 차례로 주어집니다.
[출력설명]
첫 줄에 가장 가까운 두 말의 최대 거리를 출력하세요.
5 3
1 2 8 4 9
3
이분검색(이분탐색)을 활용한 결정알고리즘의 예제이다. 이분검색이 베이스이기 때문에, 먼저 정렬하고난 이후에 문제풀이를 해야한다.
<html>
<head>
<meta charset="UTF-8">
<title>출력결과</title>
</head>
<body>
<script>
//가장 가까운 두 마리 거리를 dist로 했을 때, 몇마리를 배치할 수 있는지?
function count(stable, dist){
let cnt=1, ep=stable[0]; //한마리는 무조건 배치하기 때문에, cnt=1
//말을 배치할 수 있는지
for(let i=1; i<stable.length; i++){
//말 배치 가능
if(stable[i]-ep>=dist){
cnt++;
ep=stable[i];
}
}
return cnt;
}
function solution(c, stable){
let answer;
stable.sort((a, b)=>a-b); //정렬 먼저
let lt=1; //최소값
let rt=stable[stable.length-1]; //최댓값
//이분 검색
while(lt<=rt){
let mid=parseInt((lt+rt)/2);
if(count(stable, mid)>=c){
answer=mid;
lt=mid+1;
}
else rt=mid-1; //if문 안될때, 큰범위는 없앰
}
return answer;
}
let arr=[1, 2, 8, 4, 9];
console.log(solution(3, arr));
</script>
</body>
</html>
9/14
이분탐색은 반드시 정렬해줄것