큐 (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 DongNyeong32) 우선순위 큐 활용
- 비행기 퍼스트 클래스 / 비즈니스 클래스 / 이코노미 클래스 순으로 우선순위를 매기는 경우
 - 응급실에서 중상 환자에 따라 우선 순위에 따라 진료실로 보내는 경우
 
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입니다.