문제
https://school.programmers.co.kr/learn/courses/30/lessons/42587
풀이 과정
우선 순위가 1~9까지 있고, 문서가 1~100까지이다. 따라서 문서를 우선순위에 따라 정렬하지 않고, int 1차원 배열에 각 우선 순위가 몇 개 있는지 표시하였다.
그리고나서 우선순위를 9부터 1까지 차례로 탐색하면서, 해당 우선순위를 가진 문서가 1개 이상이면 queue에서 찾도록 했다.
import java.util.*;
class Solution {
public int solution(int[] priorities, int location) {
int answer = 0;
int[] cnt = new int[10];
Queue<int[]> q = new LinkedList<>();
for(int i=0, size = priorities.length; i<size; i++){
cnt[priorities[i]]++;
q.add(new int[]{i, priorities[i]});
}
int priority = 9;
while(priority >= 0){
if(cnt[priority] > 0){
int[] now = q.poll();
if(now[1] == priority){
cnt[priority]--;
answer++;
if(now[0] == location){
break;
}
}
else{
q.add(now);
}
}
else{
priority--;
}
}
return answer;
}
}
'코딩문제풀이 > 프로그래머스' 카테고리의 다른 글
[Java] 프로그래머스 : 로또의 최고 순위와 최저 순위 (0) | 2023.04.26 |
---|---|
[Java] 프로그래머스 : 퍼즐 조각 채우기 (0) | 2023.04.13 |
[Java] 프로그래머스 : 모음사전 (0) | 2023.04.04 |
[Java] 프로그래머스 : 양궁대회 (0) | 2022.10.10 |
[Java] 프로그래머스 : 불량 사용자* (0) | 2022.09.29 |