Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- coding test
- SQL
- 코딩테스트
- 정렬
- 배열
- HashMap
- Naver
- string
- HTML
- point queue
- javac
- hash
- programmers
- Python
- 스파르타코딩클럽
- CSS
- 해쉬
- 프로그래머스
- 자바
- 자료구조
- Eclipse
- 네이버
- 우선순위큐
- Stack
- compare()
- Java
- Queue
- array
- HashSet
- Coding
Archives
- Today
- Total
youngik
스택/큐 (프린터) 본문
먼저 위 문제를 분석해봤을 때,
1. (중요도, 위치값)를 가진 Point쌍의 값을 queue에 넣는다.
2. 각 cycle마다 현재 남은 queue의 중요도가 가장 큰 값과 비교를 한다.
3. 맨 앞에 값을 poll() 해봤을 때 max값과 일치하면 output queue에 넣고 작으면 다시 queue에 add()한다.
(*1-3번의 작업은 priority 큐가 비어있을 때 까지 반복)
4. 1-3번의 작업이 끝나면 output queue에서 location과 일치하는 위치값을 출력한다. (몇번째로 출력되는지)
-> 예제 문제에서 봤을 때, 동일한 값이라도 출력되는 순서가 다르기 때문에 원래 queue에서 위치값을 같이 저장했다.
-> 몇번째로 인쇄됐는지 결과값을 물어볼때 0이 아닌 1부터 시작하기 때문에 조건을 만족하면 i++를 하고 넣어줬다.
'programmers' 카테고리의 다른 글
해시 (전화번호 목록) (0) | 2021.04.09 |
---|---|
완전탐색 (모의고사) (0) | 2021.04.07 |
정렬 (H-index) (0) | 2021.04.07 |
스택/큐 (기능개발) (0) | 2021.04.07 |
스택/큐 (주식가격) (0) | 2021.04.07 |
Comments