문제 출처 : https://school.programmers.co.kr/learn/courses/30/lessons/42626
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 설명
매운 것을 좋아하는 Leo는 모든 음식의 스코빌 지수를 K 이상으로 만들고 싶습니다. 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 Leo는 스코빌 지수가 가장 낮은 두 개의 음식을 아래와 같이 특별한 방법으로 섞어 새로운 음식을 만듭니다.
- 섞은 음식의 스코빌 지수 = 가장 맵지 않은 음식의 스코빌 지수 + (두 번째로 맵지 않은 음식의 스코빌 지수 * 2)
Leo는 모든 음식의 스코빌 지수가 K 이상이 될 때까지 반복하여 섞습니다.
Leo가 가진 음식의 스코빌 지수를 담은 배열 scoville과 원하는 스코빌 지수 K가 주어질 때, 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 섞어야 하는 최소 횟수를 return 하도록 solution 함수를 작성해주세요.
입출력 예제
풀이
우선순위 큐를 사용하여 scoville을 넣어서 while문으로 K이상이 될때까지 반복하였습니다.
poll()을 2번 사용하기 때문에 size() > 1로 설정하였고 마지막에 poll()을 통해 K보다 작으면 -1을 return 해주었습니다.
코드
import java.util.*;
class Solution {
public int solution(int[] scoville, int K) {
PriorityQueue<Integer> scovillePriorityQueue = new PriorityQueue<>();
int answer = 0;
for(int foodScoville : scoville) {
scovillePriorityQueue.add(foodScoville);
}
while(scovillePriorityQueue.size() > 1 && scovillePriorityQueue.peek() < K) {
scovillePriorityQueue.add(scovillePriorityQueue.poll()
+ (scovillePriorityQueue.poll() * 2));
answer++;
}
if(scovillePriorityQueue.poll() < K) {
answer = -1;
}
return answer;
}
}
제한 사항
'Algorithm > Programmers' 카테고리의 다른 글
[Algorithm][Programmers] 소수 찾기 (Java) (0) | 2023.07.25 |
---|---|
[Algorithm][Programmers] 폰켓몬 (Java) (0) | 2023.07.20 |
[Algorithm][Programmers] 체육복 (Java) (0) | 2023.07.20 |
[Algorithm][Programmers] 최소직사각형 (Java) (0) | 2023.07.20 |
[Algorithm][Programmers] K번째수 (Java) (0) | 2023.07.20 |