本篇內(nèi)容主要講解“JavaScript數(shù)據(jù)結(jié)構(gòu)之優(yōu)先隊(duì)列與循環(huán)隊(duì)列如何實(shí)現(xiàn)”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“JavaScript數(shù)據(jù)結(jié)構(gòu)之優(yōu)先隊(duì)列與循環(huán)隊(duì)列如何實(shí)現(xiàn)”吧!
創(chuàng)新互聯(lián)建站是一家集網(wǎng)站建設(shè),金州企業(yè)網(wǎng)站建設(shè),金州品牌網(wǎng)站建設(shè),網(wǎng)站定制,金州網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,金州網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
優(yōu)先隊(duì)列
實(shí)現(xiàn)一個優(yōu)先隊(duì)列:設(shè)置優(yōu)先級,然后在正確的位置添加元素。
我們這里實(shí)現(xiàn)的是最小優(yōu)先隊(duì)列,優(yōu)先級的值?。▋?yōu)先級高)的元素被放置在隊(duì)列前面。
//創(chuàng)建一個類來表示優(yōu)先隊(duì)列 function Priorityqueue(){ var items=[];//保存隊(duì)列里的元素 function QueueEle(e,p){//元素節(jié)點(diǎn),有兩個屬性 this.element=e;//值 this.priority=p;//優(yōu)先級 } this.enqueue=function(e,p){//添加一個元素到隊(duì)列尾部 var queueEle=new QueueEle(e,p); var added=false; //priority小的優(yōu)先級高,優(yōu)先級高的在隊(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é)果:
在正確的位置添加元素:如果隊(duì)列為空,可以直接將元素入列。否則,就需要比較該元素與其他元素的優(yōu)先級。當(dāng)找到一個比要添加的元素優(yōu)先級更低的項(xiàng)時,就把新元素插入到它之前,這樣,對于其他優(yōu)先級相同,但是先添加到隊(duì)列的元素,我們同樣遵循先進(jìn)先出的原則。
最大優(yōu)先隊(duì)列:優(yōu)先級的值大的元素放置在隊(duì)列前面。
循環(huán)隊(duì)列
實(shí)現(xiàn)擊鼓傳花游戲。
//創(chuàng)建一個類來表示隊(duì)列 function Queue(){ var items=[];//保存隊(duì)列里的元素 this.enqueue=function(e){//添加一個元素到隊(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ì)列包含的元素個數(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é)果:
得到一份名單,把里面的名字全都加入隊(duì)列。給定一個數(shù)字,然后迭代隊(duì)列。從隊(duì)列頭移除一項(xiàng),加入到隊(duì)列尾部,模擬循環(huán)隊(duì)列。一旦傳遞次數(shù)達(dá)到給定的數(shù)字,拿到花的那個人就被淘汰。最后只剩一個人的時候,他就是勝利者。
到此,相信大家對“JavaScript數(shù)據(jù)結(jié)構(gòu)之優(yōu)先隊(duì)列與循環(huán)隊(duì)列如何實(shí)現(xiàn)”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
文章標(biāo)題:JavaScript數(shù)據(jù)結(jié)構(gòu)之優(yōu)先隊(duì)列與循環(huán)隊(duì)列如何實(shí)現(xiàn)
分享鏈接:http://m.newbst.com/article10/gdepdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、服務(wù)器托管、建站公司、微信小程序、虛擬主機(jī)、網(wǎng)站維護(hù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)