https://programmers.co.kr/learn/courses/30/lessons/42885
코딩테스트 연습 - 구명보트
무인도에 갇힌 사람들을 구명보트를 이용하여 구출하려고 합니다. 구명보트는 작아서 한 번에 최대 2명씩 밖에 탈 수 없고, 무게 제한도 있습니다. 예를 들어, 사람들의 몸무게가 [70kg, 50kg, 80kg, 5
programmers.co.kr
누가 봐도 그리디 하다.
두명씩만 탈 수 있는 제한 조건때문에 투 포인터 식으로 풀어보았다.
코드를 보자.
import java.io.*;
import java.util.*;
class Solution {
public int solution(int[] people, int limit) {
int answer = 0;
long sum = 0;
int lc=0;
int rc = people.length - 1;
Arrays.sort(people);
while(rc>=lc){
sum = people[rc] + people[lc];
if(sum>limit){
rc--;
answer++;
}
else{
rc--; lc++;
answer++;
}
}
return answer;
}
}
우선 sum 을 구하는데 sum 이 limit 을 넘으면 무거운 친구는 혼자 타야한다. 그래서 rc-- 해주고 answer++ 해준다.
limit 을 안넘으면 둘이 같이 타면 된다. 이 둘이 같이 타는게 왜 최선의 선택인지 좀 어렴풋이 알겠는데 그리디한 문제는 일단 믿고 가야한다.
'Algorithm > Programmers' 카테고리의 다른 글
[Programmers - 자바] 가장 큰 수 (0) | 2022.03.30 |
---|---|
[Programmers - 자바] 거리두기 확인하기 (0) | 2022.03.16 |
[Programmers - 자바] 문자열 압축 (0) | 2022.03.13 |
[Programmers - c++] 신규 아이디 추천 (0) | 2022.02.13 |
[Programmers - c++] 비밀지도 (0) | 2022.02.13 |