JavaScript實(shí)現(xiàn)優(yōu)先級隊(duì)列
一、優(yōu)先級隊(duì)列介紹
我們知道,普通的隊(duì)列插入一個元素,數(shù)據(jù)會被放在后端,并且需要前面所有的元素都處理完成后才會處理前面的數(shù)據(jù)。但是優(yōu)先級隊(duì)列,在插入一個元素的時候會考慮該數(shù)據(jù)的優(yōu)先級,和其他數(shù)據(jù)的優(yōu)先級進(jìn)行比較。比較完成后,可以得出這個元素在隊(duì)列中的正確位置,其他的處理方式,和基本隊(duì)列的處理方式基本一樣。
優(yōu)先級隊(duì)列主要考慮的問題:
- 每個元素不再只是一個數(shù)據(jù),而且包含數(shù)據(jù)的優(yōu)先級;
- 在添加方式中,根據(jù)優(yōu)先級放入正確的位置。
在日常中也有用到優(yōu)先級隊(duì)列的例子,比如說醫(yī)院的(急診科)候診室。醫(yī)生會優(yōu)先處理病情比較嚴(yán)重的患者。計(jì)算機(jī)中,我們也可以通過優(yōu)先級隊(duì)列來重新排列隊(duì)列中任務(wù)的順序.比如每個線程處理的任務(wù)重要性不同,我們可以通過優(yōu)先級的大小,來決定該線程在隊(duì)列中被處理的次序。
二、優(yōu)先級隊(duì)列封裝
優(yōu)先級隊(duì)列的操作和隊(duì)列的操作方法基本相同,但是插入操作有所不同,所以,我們這里主要是來實(shí)現(xiàn)優(yōu)先級隊(duì)列的插入操作。
比如說我們現(xiàn)在要根據(jù)某個數(shù)據(jù)的優(yōu)先級來插入元素,這里我們先創(chuàng)建一個類來封裝優(yōu)先級隊(duì)列,并在其內(nèi)部創(chuàng)建一個構(gòu)造函數(shù)來保存元素的優(yōu)先級和數(shù)據(jù),再添加一個屬性用于存放元素。
代碼如下:
function PtiorityQueue(){
var items = [];
//封裝一個新的構(gòu)造函數(shù),用于保存元素和元素的優(yōu)先級
function queueElement(element,priority){
this.element = element;
this.priority = priority;
}
}
創(chuàng)建完成后,在來實(shí)現(xiàn)其的插入操作:
- 如果隊(duì)列內(nèi)部沒有元素,則直接插入
- 如果要插入的元素的優(yōu)先級小于隊(duì)列內(nèi)部元素的優(yōu)先級,則排序后插入。
具體實(shí)現(xiàn)代碼如下:
function PtiorityQueue(){
this.items = [];
//封裝一個新的構(gòu)造函數(shù),用于保存元素和元素的優(yōu)先級
function QueueElement(element,priority){
this.element = element;
this.priority = priority;
}
//1.實(shí)現(xiàn)插入方法
PtiorityQueue.prototype.enqueue = function(element,priority){
//1.創(chuàng)建queueElement對象
var queueElement = new QueueElement(element,priority);
//2.判斷隊(duì)列是否為空
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)
}
}
}
}
輸入測試數(shù)據(jù)為:
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);
打印結(jié)果為:

到此這篇關(guān)于JavaScript實(shí)現(xiàn)優(yōu)先級隊(duì)列的文章就介紹到這了,更多相關(guān)優(yōu)先級隊(duì)列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
微信小程序 tabs選項(xiàng)卡效果的實(shí)現(xiàn)
這篇文章主要介紹了微信小程序 tabs選項(xiàng)卡效果的實(shí)現(xiàn)的相關(guān)資料,微信小程序內(nèi)部組件沒有Tabs 選項(xiàng)卡的功能,自己實(shí)現(xiàn)個類似的,需要的朋友可以參考下2017-01-01
JS開發(fā)前端團(tuán)隊(duì)展示控制器來為成員引流
這篇文章主要為大家介紹了JS開發(fā)前端團(tuán)隊(duì)展示控制器實(shí)現(xiàn)為成員引流示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
javascript 操作cookies詳解及實(shí)例
這篇文章主要介紹了javascript 操作cookies詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-02-02
微信小程序 swiper組件構(gòu)建輪播圖的實(shí)例
這篇文章主要介紹了微信小程序 swiper組件構(gòu)建輪播圖的實(shí)例的相關(guān)資料,如有疑問請留言或者到本站社區(qū)交流討論,需要的朋友可以參考下2017-09-09

