본문 바로가기
Algorithm/Programmers Java

Java 프로그래머스 더 맵게

by 제우제우 2024. 3. 4.

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

 

프로그래머스

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

programmers.co.kr

문제 분류 : 코딩테스트 연습 > 힙(Heap) > 더 맵게

난이도 : 2

 

정답 코드 

import java.util.*;
class Solution {
    public int solution(int[] scoville, int K) {
        PriorityQueue<Integer> pq = new PriorityQueue<>();
        for(int target : scoville){
            pq.add(target);
        }
        int cnt = 0;
        boolean flag = false;
        while(pq.size() >=1){
            if(pq.peek() >= K){
                flag = true;
                break;
            }
            cnt++;
            if(pq.size() == 1) break;
            int temp = pq.poll();
            int temp2 = pq.poll();
            pq.add(temp + temp2 * 2);
        }
        if(!flag) return -1;
        return cnt;
    }
}