欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

本篇內(nèi)容介紹了“JavaScript優(yōu)先隊(duì)列與循環(huán)隊(duì)列怎么實(shí)現(xiàn)”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

成都創(chuàng)新互聯(lián)公司長期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為龍陵企業(yè)提供專業(yè)的做網(wǎng)站、成都網(wǎng)站制作,龍陵網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

優(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è)類來表示優(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優(yōu)先隊(duì)列與循環(huán)隊(duì)列怎么實(shí)現(xiàn)

在正確的位置添加元素:如果隊(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è)類來表示隊(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優(yōu)先隊(duì)列與循環(huán)隊(duì)列怎么實(shí)現(xiàn)

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

“JavaScript優(yōu)先隊(duì)列與循環(huán)隊(duì)列怎么實(shí)現(xiàn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

名稱欄目:JavaScript優(yōu)先隊(duì)列與循環(huán)隊(duì)列怎么實(shí)現(xiàn)
URL標(biāo)題:http://aaarwkj.com/article20/phopjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、全網(wǎng)營銷推廣、網(wǎng)站策劃、外貿(mào)網(wǎng)站建設(shè)網(wǎng)站收錄、搜索引擎優(yōu)化

廣告

聲明:本網(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í)需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
人妻少妇中文字幕一区| 十八禁网站免费在线播放| 久久国产精品99亚洲| 亚洲综合欧美自偷自拍| 国产一区二区三区精品女同 | 少妇诱惑一区二区三区| 国产日产精品久久婷婷色| 最新国产激情福利网站| 亚洲欧美日韩高清一区二区| 日韩成人大片在线播放| 午夜宅男在线视频观看| 国产b片免费在线观看| 日韩福利小视频在线| 亚洲三级成人一区在线| 蜜臀视频在线观看免费| 五月天亚洲激情综合av| 国产龙熟女高潮一区二区| 免费国产网站在线观看不卡| 免费的黄色片带中文字幕| 亚洲国产日韩欧美第一页| 午夜影院在线观看网站| 日本一道二区三区我不卡| 色哟哟网站一区二区精品久久| 欧美日韩另类激情免费| 国产一区二区三区精品女同| 久久夜色精品国产高清不卡| 日韩欧美性生活免费观看| 亚洲精品国产熟女av| 91精品国产综合久蜜臂| 自拍偷拍亚洲精品第一页| 亚洲中文有码在线播放| 91香蕉国产在线观看| 国内精品老年人视频网站| 国产视频不卡一区二区| 年轻的母亲韩国三级| 日本经典三级视频在线观看| 日本三级黄色免费的网站| 人妻一区日韩二区国产| 97视频观看免费观看| 在线免费观看日本91| 免费人妻一区二区三区|