JS优先队列

基于JS的优先队列实现

/**
 * 优先队列
 */
class PriorityQueue {
  constructor(compare,data) {
     if(typeof compare !=='function'){
        throw new Error('compare function required!')
     }
  
     if(data){
      this.data = data
     }else{
      this.data = []
     }
     this.compare = compare
  }
  //二分查找 寻找插入位置
  search(target) {
    let low = 0, high = this.data.length
    while (low < high) {
      let mid = low + ((high - low) >> 1)
      if (this.compare(this.data[mid], target) > 0) {
        high = mid
      }
      else {
        low = mid + 1
      }
    }
    return low;
  }
  //添加
  push(elem) {
    let index = this.search(elem)
    this.data.splice(index, 0, elem)
    return this.data.length
  }
  //取出最优元素
  pop() {
    return this.data.pop()
  }
  //查看最优元素
  peek() {
    return this.data[this.data.length - 1];
  }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一般情况下从队列中删除的元素,一定是率先入队的元素。但是也有一些使用队列的应用,在删除元素时不必遵守先进先出的约定...
    JunChow520阅读 6,070评论 0 1
  • 这节总结一下优先队列的常用实现方法。 目录: 1、基本概念 2、基于数组实现的优先队列 2.1、基于有序数组的实现...
    Alent阅读 5,171评论 0 8
  • 一、栈 1.什么是栈? 栈stack是一种特殊的线性表,这种线性表只能在固定一端(通常认为是线性表的尾端)进行插入...
    alex很累阅读 4,654评论 0 0
  • 什么是优先队列 我们都知道队列是一种先进先出、后进后出的数据结构,就如同日常生活中的排队一样,先到先得。而优先队列...
    端碗吹水阅读 3,021评论 0 1
  • 一,优先队列 在决定病人接受治疗的次序时,除了他们到达医院的先后次序,更主要的将取决于病情的严重程度。由这类问题可...
    峰峰小阅读 4,264评论 0 0