溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列

發(fā)布時間:2022-05-19 11:30:23 來源:億速云 閱讀:228 作者:zzz 欄目:大數(shù)據(jù)

這篇文章主要介紹了JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列文章都會有所收獲,下面我們一起來看看吧。

優(yōu)先隊列

實現(xiàn)一個優(yōu)先隊列:設(shè)置優(yōu)先級,然后在正確的位置添加元素。

我們這里實現(xiàn)的是最小優(yōu)先隊列,優(yōu)先級的值?。▋?yōu)先級高)的元素被放置在隊列前面。

//創(chuàng)建一個類來表示優(yōu)先隊列
function Priorityqueue(){
  var items=[];//保存隊列里的元素
  function QueueEle(e,p){//元素節(jié)點,有兩個屬性
    this.element=e;//值
    this.priority=p;//優(yōu)先級
  }
  this.enqueue=function(e,p){//添加一個元素到隊列尾部
    var queueEle=new QueueEle(e,p);
    var added=false;
    //priority小的優(yōu)先級高,優(yōu)先級高的在隊頭
    if(this.isEmpty()){
      items.push(queueEle);
    }else{
      for(var i=0;i<items.length;i++){
        if(items[i].priority>queueEle.priority){
          items.splice(i,0,queueEle);
          added=true;
          break;
        }
      }
      if(!added){
        items.push(queueEle);
      }
    }
  }
  this.isEmpty=function(){
    return items.length==0;
  }
  this.dequeue=function(){
    return items.shift();
  }
  this.clear=function(){
    items=[];
  }
  this.print=function(){
    console.log(items);
  }
  this.mylength=function(){
    return items.length;
  }
}
var pqueue=new Priorityqueue();
pqueue.enqueue('a',2);
pqueue.enqueue('b',1);
pqueue.enqueue('c',2);
pqueue.enqueue('d',2);
pqueue.enqueue('e',1);
pqueue.print();
//[ QueueEle { element: 'b', priority: 1 },
// QueueEle { element: 'e', priority: 1 },
// QueueEle { element: 'a', priority: 2 },
// QueueEle { element: 'c', priority: 2 },
// QueueEle { element: 'd', priority: 2 } ]

運(yùn)行結(jié)果:

JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列

在正確的位置添加元素:如果隊列為空,可以直接將元素入列。否則,就需要比較該元素與其他元素的優(yōu)先級。當(dāng)找到一個比要添加的元素優(yōu)先級更低的項時,就把新元素插入到它之前,這樣,對于其他優(yōu)先級相同,但是先添加到隊列的元素,我們同樣遵循先進(jìn)先出的原則。

最大優(yōu)先隊列:優(yōu)先級的值大的元素放置在隊列前面。

循環(huán)隊列

實現(xiàn)擊鼓傳花游戲。

//創(chuàng)建一個類來表示隊列
function Queue(){
  var items=[];//保存隊列里的元素
  this.enqueue=function(e){//添加一個元素到隊列尾部
    items.push(e);
  }
  this.dequeue=function(){//移除隊列的第一項,并返回
    return items.shift();
  }
  this.front=function(){//返回隊列的第一項
    return items[0];
  }
  this.isEmpty=function(){//如果隊列中部包含任何元素,返回true,否則返回false
    return items.length==0;
  }
  this.mylength=function(){//返回隊列包含的元素個數(shù)
    return items.length;
  }
  this.clear=function(){//清除隊列中的元素
    items=[];
  }
  this.print=function(){//打印隊列中的元素
    console.log(items);
  }
}
//擊鼓傳花
function hotPotato(namelist,num){
  var queue=new Queue();
  for(var i=0;i<namelist.length;i++){
    queue.enqueue(namelist[i]);
  }
  var eliminated='';
  while(queue.mylength()>1){
    for(i=0;i<num;i++){
      queue.enqueue(queue.dequeue());
    }
    eliminated=queue.dequeue();
    console.log("淘汰"+eliminated);
  }
  return queue.dequeue();
}
var namelist=['a','b','c','d','e'];
var winner=hotPotato(namelist,7);
console.log(winner+"獲勝");
//淘汰c
//淘汰b
//淘汰e
//淘汰d
//a獲勝

運(yùn)行結(jié)果:

JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列

得到一份名單,把里面的名字全都加入隊列。給定一個數(shù)字,然后迭代隊列。從隊列頭移除一項,加入到隊列尾部,模擬循環(huán)隊列。一旦傳遞次數(shù)達(dá)到給定的數(shù)字,拿到花的那個人就被淘汰。最后只剩一個人的時候,他就是勝利者。

關(guān)于“JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“JavaScript如何實現(xiàn)優(yōu)先隊列與循環(huán)隊列”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI