[프로그래머스 / C++] 더 맵게

Seulguo·2022년 7월 7일
0

Algorithm

목록 보기
20/185
post-thumbnail
post-custom-banner

🐣 문제

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


🐥 코드

#include <string>
#include <vector>
#include <queue> 

using namespace std;

int solution(vector<int> scoville, int K) {
    int answer = 0;
    
    priority_queue<int, vector<int>, greater<int>> pq;
    
    for(int i = 0; i < scoville.size(); i++){
        pq.push(scoville[i]);
    }
    
    while(pq.top() < K){
        
        if(pq.size() == 1){
            return -1;
        }

        int last = pq.top();
        pq.pop();
        int last_second = pq.top();
        pq.pop();
        
        int temp = last + (last_second * 2);
        pq.push(temp);
        answer ++; 
    }
    
    return answer;
}
post-custom-banner

0개의 댓글