몽땅뚝딱 개발자

[프로그래머스 | Javascript] Lv.2 더 맵게 본문

카테고리 없음

[프로그래머스 | Javascript] Lv.2 더 맵게

레오나르도 다빈츠 2024. 12. 28. 19:13

 

1차 풀이

효율성에서 탈락.. 결국 힙을 써야했다.

function solution(scoville, K) {
  const heap = scoville.sort((a, b) => a - b)

  let count = 0;
  while (heap.length > 1 && heap[0] < K) {
    const first = heap.shift();
    const second = heap.shift();

    const newScoville = first + (second * 2);
    heap.push(newScoville);
    heap.sort((a, b) => a - b);
    count++;
  }

  return heap[0] >= K ? count : -1;
}

 

 

2차 풀이

GPT의 도움을 빌려 MinHeap class를 만들어서 풀었다.

힙을 공부하고 시작했지만 구현하기는 힘든거보니 제대로 공부한게 아닌가보다🤦🏻‍♀️

class MinHeap {
  constructor() {
    this.heap = [];
  }

  insert(value) {
    this.heap.push(value);
    this._heapifyUp();
  }

  extractMin() {
    if (this.heap.length <= 1) return this.heap.pop();
    const min = this.heap[0];
    this.heap[0] = this.heap.pop();
    this._heapifyDown();
    return min;
  }

  _heapifyUp() {
    let index = this.heap.length - 1;
    while (index > 0) {
      const parentIndex = Math.floor((index - 1) / 2);
      if (this.heap[index] >= this.heap[parentIndex]) break;
      [this.heap[index], this.heap[parentIndex]] = [this.heap[parentIndex], this.heap[index]];
      index = parentIndex;
    }
  }

  _heapifyDown() {
    let index = 0;
    const length = this.heap.length;
    while (index < length) {
      const leftChildIndex = 2 * index + 1;
      const rightChildIndex = 2 * index + 2;
      let smallest = index;

      if (leftChildIndex < length && this.heap[leftChildIndex] < this.heap[smallest]) {
        smallest = leftChildIndex;
      }
      if (rightChildIndex < length && this.heap[rightChildIndex] < this.heap[smallest]) {
        smallest = rightChildIndex;
      }
      if (smallest === index) break;
      [this.heap[index], this.heap[smallest]] = [this.heap[smallest], this.heap[index]];
      index = smallest;
    }
  }
}

function solution(scoville, K) {
  const heap = new MinHeap();
  for (let num of scoville) {
    heap.insert(num);
  }

  let count = 0;
  while (heap.heap.length > 1 && heap.heap[0] < K) {
    const first = heap.extractMin();
    const second = heap.extractMin();
    const newScoville = first + (second * 2);
    heap.insert(newScoville);
    count++;
  }

  return heap.heap[0] >= K ? count : -1;
}
Comments