久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

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

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

站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到梅江網(wǎng)站設(shè)計(jì)與梅江網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站建設(shè)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名與空間、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋梅江地區(qū)。

優(yōu)先隊(duì)列

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

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

//創(chuàng)建一個(gè)類來(lái)表示優(yōu)先隊(duì)列
function Priorityqueue(){
  var items=[];//保存隊(duì)列里的元素
  function QueueEle(e,p){//元素節(jié)點(diǎn),有兩個(gè)屬性
    this.element=e;//值
    this.priority=p;//優(yōu)先級(jí)
  }
  this.enqueue=function(e,p){//添加一個(gè)元素到隊(duì)列尾部
    var queueEle=new QueueEle(e,p);
    var added=false;
    //priority小的優(yōu)先級(jí)高,優(yōu)先級(jí)高的在隊(duì)頭
    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如何實(shí)現(xiàn)優(yōu)先隊(duì)列與循環(huán)隊(duì)列

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

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

循環(huán)隊(duì)列

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

//創(chuàng)建一個(gè)類來(lái)表示隊(duì)列
function Queue(){
  var items=[];//保存隊(duì)列里的元素
  this.enqueue=function(e){//添加一個(gè)元素到隊(duì)列尾部
    items.push(e);
  }
  this.dequeue=function(){//移除隊(duì)列的第一項(xiàng),并返回
    return items.shift();
  }
  this.front=function(){//返回隊(duì)列的第一項(xiàng)
    return items[0];
  }
  this.isEmpty=function(){//如果隊(duì)列中部包含任何元素,返回true,否則返回false
    return items.length==0;
  }
  this.mylength=function(){//返回隊(duì)列包含的元素個(gè)數(shù)
    return items.length;
  }
  this.clear=function(){//清除隊(duì)列中的元素
    items=[];
  }
  this.print=function(){//打印隊(duì)列中的元素
    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如何實(shí)現(xiàn)優(yōu)先隊(duì)列與循環(huán)隊(duì)列

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

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

分享名稱:JavaScript如何實(shí)現(xiàn)優(yōu)先隊(duì)列與循環(huán)隊(duì)列
URL鏈接:http://sd-ha.com/article32/gcjcpc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、外貿(mào)網(wǎng)站建設(shè)、用戶體驗(yàn)、微信小程序、微信公眾號(hào)、動(dòng)態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)