JavaScript实现优先级队列

作者:bear*6 时间:2024-05-02 16:19:06 

一、优先级队列介绍

我们知道,普通的队列插入一个元素,数据会被放在后端,并且需要前面所有的元素都处理完成后才会处理前面的数据。但是优先级队列,在插入一个元素的时候会考虑该数据的优先级,和其他数据的优先级进行比较。比较完成后,可以得出这个元素在队列中的正确位置,其他的处理方式,和基本队列的处理方式基本一样。

优先级队列主要考虑的问题:

  • 每个元素不再只是一个数据,而且包含数据的优先级;

  • 在添加方式中,根据优先级放入正确的位置。

在日常中也有用到优先级队列的例子,比如说医院的(急诊科)候诊室。医生会优先处理病情比较严重的患者。计算机中,我们也可以通过优先级队列来重新排列队列中任务的顺序.比如每个线程处理的任务重要性不同,我们可以通过优先级的大小,来决定该线程在队列中被处理的次序。

二、优先级队列封装

优先级队列的操作和队列的操作方法基本相同,但是插入操作有所不同,所以,我们这里主要是来实现优先级队列的插入操作

比如说我们现在要根据某个数据的优先级来插入元素,这里我们先创建一个类来封装优先级队列,并在其内部创建一个构造函数来保存元素的优先级和数据,再添加一个属性用于存放元素。

代码如下:


function PtiorityQueue(){
           var items = [];
           //封装一个新的构造函数,用于保存元素和元素的优先级
           function queueElement(element,priority){
               this.element = element;
               this.priority = priority;
           }
       }

创建完成后,在来实现其的插入操作:

  • 如果队列内部没有元素,则直接插入

  • 如果要插入的元素的优先级小于队列内部元素的优先级,则排序后插入。

具体实现代码如下:


function PtiorityQueue(){
  this.items = [];
   //封装一个新的构造函数,用于保存元素和元素的优先级
   function QueueElement(element,priority){
       this.element = element;
       this.priority = priority;
   }
    //1.实现插入方法
    PtiorityQueue.prototype.enqueue = function(element,priority){
       //1.创建queueElement对象
       var queueElement = new QueueElement(element,priority);
       //2.判断队列是否为空
       if(this.items.length == 0){
           this.items.push(queueElement);
       }else{
           var flag = false;
           for(var i =0;i<this.items.length;i++){
               if(queueElement.priority < this.items[i].priority){
                   this.items.splice(i,0,queueElement);
                   flag = true;
                   break;
               }
           }
           if(!flag){
               this.items.push(queueElement)
           }
       }
    }
}

输入测试数据为:

var pq = new PtiorityQueue();
        pq.enqueue('d',30)
        pq.enqueue('c',50)
        pq.enqueue('a',100)
        pq.enqueue('b',60)
        pq.enqueue('e',20)
        console.log(pq);

打印结果为:

JavaScript实现优先级队列

来源:https://blog.csdn.net/m0_48375854/article/details/121642038

标签:JavaScript,优先级队列
0
投稿

猜你喜欢

  • 详解用Python处理Args的3种方法

    2023-01-21 17:10:10
  • Python中最大最小赋值小技巧(分享)

    2021-08-26 06:07:44
  • python对文件的操作方法汇总

    2023-04-13 18:52:59
  • Python编写车票订购系统 Python实现快递收费系统

    2023-06-26 15:37:26
  • 解决Server对象 错误 'ASP 0178 : 80070005'

    2008-02-29 13:45:00
  • 当标题不能显示完整的时候

    2007-11-20 13:23:00
  • python实现kmp算法的实例代码

    2022-07-19 15:07:16
  • Tesserocr库的正确安装方式

    2023-12-26 17:19:34
  • 关于Python中的if __name__ == __main__详情

    2022-05-04 10:16:28
  • 23个MySQL数据库安全使用技巧

    2007-10-26 16:02:00
  • python判断设备是否联网的方法

    2022-05-03 12:34:55
  • FileSystem对象常用的文件操作函数有哪些?

    2009-11-01 15:11:00
  • python切片操作方法的实例总结

    2021-02-28 12:51:01
  • python常见字符串处理函数与用法汇总

    2023-10-19 08:07:11
  • Python多线程爬虫简单示例

    2022-04-30 13:35:40
  • 详解Go语言strconv与其他基本数据类型转换函数的使用

    2024-04-23 09:42:17
  • ASP用户登录验证代码

    2008-05-15 12:49:00
  • 简单获取键盘的KeyCode

    2008-04-18 12:37:00
  • 跟我学习javascript的作用域与作用域链

    2024-04-22 12:56:40
  • Go方法接收者值接收者与指针接收者详解

    2024-02-17 04:30:45
  • asp之家 网络编程 m.aspxhome.com