큐 (Queue)
큐 (Queue)
1. 큐
- FIFO(first In first out)
- 선입 선출
- ex) 출력문 인쇄 대기
2. 큐 만들기
1) 큐 클래스 생성
function Queue() {
// property & method 기술하기
}
2) 큐의 원소를 담아둘 자료 구조
var item = [];
3) 큐에 필요한 메서드 정리
- enqueue('원소들’) : 큐의 뒤쪽에 원소 추가
- dequeue() : 큐의 첫 번째 원소를 반환하고 큐에서 삭제
- front() : 큐 첫번째의 원소를 반환하고 해당 원소 제거를 제거 하지 않음 ( 스택 변경 X)
- isEmpty() : 큐 원소가 한개도 없으면 True / 스택 크기가 0보다 크면 False 반환
- size() : 큐의 원소 개수 반환
4) Queue 클래스
function Queue() {
let items = [];
this.enqueue = function (element) {
items.push(element);
};
this.dequeue = function () {
// shift()는 배열의 첫번째 요소를 제거하고 반환함 / pop()은 배열의 마지막 요소를 제거하고 반환함
return items.shift();
};
this.front = function () {
return items[0];
};
this.isEmpty = function () {
return items.length === 0;
};
this.size = function () {
return items.length;
};
this.clear = function () {
items = [];
};
this.print = function () {
console.log(items.toString());
};
}
let queue = new Queue();
console.log(queue.isEmpty()); // outputs true
queue.enqueue("DongNyeong");
queue.enqueue("DongNyeong2");
queue.enqueue("DongNyeong3");
queue.print(); // outputs [DongNyeong, DongNyeong2, DongNyeong3]
console.log(queue.size()); // outputs 3
console.log(queue.isEmpty()); // outputs false
queue.dequeue(); //output DongNyeong removed DongNyeong from the queue
queue.dequeue(); //output DongNyeong2 removed DongNyeong2 from the queue
queue.print(); // outputs DongNyeong3
2) 우선순위 큐 활용
- 비행기 퍼스트 클래스 / 비즈니스 클래스 / 이코노미 클래스 순으로 우선순위를 매기는 경우
- 응급실에서 중상 환자에 따라 우선 순위에 따라 진료실로 보내는 경우
function PriorityQueue() {
let items = [];
function QueueElement(element, priority) {
this.element = element;
this.priority = priority;
}
this.enqueue = function (element, priority) {
let queueElement = new QueueElement(element, priority);
if (this.isEmpty()) {
items.push(queueElement);
} else {
let added = false;
for (let i = 0; i < items.length; i++) {
if (queueElement.priority < items[i].priority) {
items.splice(i, 0, queueElement);
added = true;
break;
}
}
if (!added) {
items.push(queueElement);
}
}
this.print();
};
this.isEmpty = function () {
return items.length === 0;
};
this.print = function () {
console.log(items.toString());
};
}
let priorityQueue = new PriorityQueue();
priorityQueue.enqueue("DongNyeong", 2);
priorityQueue.enqueue("DongNyeong2", 1);
priorityQueue.enqueue("DongNyeong3", 1);
3) 환형 큐(Circulator Queue) 활용
- hotpotato 게임
- 뜨거운 감자를 옆 사람에게 최대한 빠르게 전달하다 , 갑자기 동작을 멈추고 뜨거운 감자를 손에 들고 있는 아이를 벌칙으로 퇴장 시키는 게임
function hotPotato(nameList, num) {
let queue = new Queue();
for (let i = 0; i < nameList.length; i++) {
queue.enqueue(nameList[i]);
}
let eliminated = "";
while (queue.size() > 1) {
for (let i = 0; i < num; i++) {
queue.enqueue(queue.dequeue());
}
eliminated = queue.dequeue();
console.log(eliminated + "님이 Hot Potato 게임에서 제외되었습니다.");
}
return queue.dequeue();
}
let names = [
"dongnyeong1",
"dongnyeong2",
"dongnyeong3",
"dongnyeong4",
"dongnyeong5",
];
let winner = hotPotato(names, 7);
console.log("승자는: " + winner + "입니다."); //승자는: dongnyeong1입니다.
//dongnyeong3님이 Hot Potato 게임에서 제외되었습니다.
//dongnyeong2님이 Hot Potato 게임에서 제외되었습니다.
//dongnyeong5님이 Hot Potato 게임에서 제외되었습니다.
//dongnyeong4님이 Hot Potato 게임에서 제외되었습니다.
//승자는: dongnyeong1입니다.