亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

詳解堆的javascript實現方法

2019-11-19 18:46:57
字體:
來源:轉載
供稿:網友

堆的定義

最大(最?。┒咽且豢妹恳粋€節點的鍵值都不小于(大于)其孩子(如果存在)的鍵值的樹。大頂堆是一棵完全二叉樹,同時也是一棵最大樹。小頂堆是一棵完全完全二叉樹,同時也是一棵最小樹。

另外,記住這兩個概念,對寫代碼太重要了:

      1、父節點和子節點的關系:看定義

      2、完全二叉樹:參考[2]

基本操作

      1、Build(構建堆)

      2、Insert(插入)

      3、Delete(刪除:最小或者最大的那個)

代碼實現

首先,寫代碼前有兩個非常重要的點:

      1、用一個數組就可以作為堆的存儲結構,非常簡單而且易操作;

      2、另外同樣因為是數組作為存儲結構,所以父子節點之間的關系就能根據索引就輕松找到對方了。

對于JavaScript以0作為數組索引開始,關系如下:

nLeftIndex = 2 * (nFatherIndex+1) - 1;nRightIndex = 2* (nFatherIndex+1);

前面提到注意兩個概念,是有助于理解的:

       1、因為是數組,所以父子節點的關系就不需要特殊的結構去維護了,索引之間通過計算就可以得到,省掉了很多麻煩。如果是鏈表結構,就會復雜很多;

       2、完全二叉樹的概念可以參考[2],要求葉子節點從左往右填滿,才能開始填充下一層,這就保證了不需要對數組整體進行大片的移動。這也是隨機存儲結構(數組)的短板:刪除一個元素之后,整體往前移是比較費時的。這個特性也導致堆在刪除元素的時候,要把最后一個葉子節點補充到樹根節點的緣由

代碼實現:

/******************************************************* file : 堆* author : "page"* time : "2016/11/02"*******************************************************/function Heap(){ this.data = [];}Heap.prototype.print = function () { console.log("Heap: " + this.data);}Heap.prototype.build = function(data){ // 初始化 this.data = []; if (!data instanceof Array) return false; // 入堆 for (var i = 0; i < data.length; ++i) { this.insert(data[i]); } return true;}Heap.prototype.insert = function( nValue ){ if (!this.data instanceof Array) { this.data = []; } this.data.push(nValue); // 更新新節點 var nIndex = this.data.length-1; var nFatherIndex = Math.floor((nIndex-1)/2); while (nFatherIndex > 0){ if (this.data[nIndex] < this.data[nFatherIndex]) { var temp = this.data[nIndex]; this.data[nIndex] = this.data[nFatherIndex]; this.data[nFatherIndex] = temp; } nIndex = nFatherIndex; nFatherIndex = Math.floor((nIndex-1)/2); }}Heap.prototype.delete = function( ){ if (!this.data instanceof Array) { return null; } var nIndex = 0; var nValue = this.data[nIndex]; var nMaxIndex = this.data.length-1; // 更新新節點 var nLeaf = this.data.pop(); this.data[nIndex] = nLeaf; while (nIndex < nMaxIndex ){ var nLeftIndex = 2 * (nIndex+1) - 1; var nRightIndex = 2 * (nIndex+1); // 找最小的一個子節點(nLeftIndex < nRightIndex) var nSelectIndex = nLeftIndex; if (nRightIndex < nMaxIndex) { nSelectIndex = (this.data[nLeftIndex] > this.data[nRightIndex]) ? nRightIndex : nLeftIndex; } if (nSelectIndex < nMaxIndex && this.data[nIndex] > this.data[nSelectIndex] ){ var temp = this.data[nIndex]; this.data[nIndex] = this.data[nSelectIndex]; this.data[nSelectIndex] = temp; } nIndex = nSelectIndex; } return nValue;}// testvar heap = new Heap();heap.build([1, 3, 5, 11, 4, 6, 7, 12, 15, 10, 9, 8]);heap.print();// insertheap.insert(2);heap.print();// deleteheap.delete();heap.print();

關于JavaScript的幾點小結

這里是采用面向對象的一種實現方法,感覺上不是太優雅,不知道還有沒有更好的表示方法和寫法;

學習了數組的幾個用法:push和pop的操作太好用了;

判斷數組的方式也是臨時從網上搜的(instanceof),印象不深刻,不用的話下次估計還是有可能忘掉。

參考

[1]《數據結構和算法分析:C語言描述》

[2]圖解數據結構(8)――二叉堆

[3]>數據結構:堆

總結

JavaScript的數組實現了push和pop這些操作,許多其他語言也提供了類似的數據結構和操作(比如C++的Vector),同時也支持隨機操作。所以,我開始想如果這些結構上簡單的加上自動排序的概念,那么一個堆就輕松搞定了,后面看到C++ STL的make_heap就知道自己知道的太少了,但也慶幸自己思維方式是對的。JavaScript的沒有去查,我想有或者實現起來很容易;
自己去實現了之后,發現這個結構也很簡單,只要你肯去跟它親密接觸一次就可以了;

JavaScript的細節部分還是不太了解,比如數組的應用上還要再翻資料才能用;對于JavaScript的靈魂還是沒有接觸到,精髓部分需要不斷的學習和練習;

這些代碼,只要你去了解了概念,了解了編程的基礎,就可以寫的出來。但是,代碼還可以寫的更簡潔,比如delete函數求最小的子節點的時候,左右節點的索引就不需要比較,肯定是左邊的小。代碼部分感覺還是可以繼續優化和精簡的。

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩av一区二区在线观看| 精品国产一区二区三区在线观看| 日韩欧美国产成人| 亚洲国产精品大全| 亚洲视频一区二区三区| 欧美亚洲另类激情另类| 国产精品久久久亚洲| 情事1991在线| 亚洲无亚洲人成网站77777| 久久久精品电影| 九九热99久久久国产盗摄| 欧美怡红院视频一区二区三区| 国产成人精品a视频一区www| 精品国产91久久久久久| 亚洲图片欧洲图片av| 亚洲天堂av在线播放| 国产69精品99久久久久久宅男| 亚洲国产成人av在线| 国产亚洲精品高潮| 91免费精品国偷自产在线| 久久天天躁狠狠躁老女人| 亚洲福利视频在线| 精品久久久久久中文字幕| 久久99国产精品久久久久久久久| 亚洲国产日韩一区| 国产在线播放91| 日韩av在线天堂网| 秋霞午夜一区二区| 亚洲伊人第一页| 日韩精品视频在线播放| 日韩欧美中文第一页| 在线亚洲欧美视频| 精品国产一区二区三区久久| 91视频免费网站| 成人精品一区二区三区电影黑人| 欧美日韩激情视频8区| 在线中文字幕日韩| 亚洲午夜女主播在线直播| 久久久久久久久久久国产| 欧美综合激情网| 亚洲精品久久久久国产| 日韩av黄色在线观看| 欧美激情亚洲自拍| 久久久久久久国产| 伊人亚洲福利一区二区三区| 日韩欧美亚洲一二三区| 日本精品中文字幕| 色综合天天狠天天透天天伊人| 成人xvideos免费视频| 日本精品久久中文字幕佐佐木| 久久精品国产亚洲精品2020| 97在线视频免费播放| 庆余年2免费日韩剧观看大牛| 国产午夜精品一区二区三区| 国产一区二区在线播放| 日韩精品亚洲视频| 91九色单男在线观看| 亚洲色图欧美制服丝袜另类第一页| 国产成人一区三区| 色噜噜国产精品视频一区二区| 国产精品国产亚洲伊人久久| 91福利视频网| 97人人做人人爱| 欧美激情精品久久久久久大尺度| 亚洲成色777777女色窝| 国色天香2019中文字幕在线观看| 久久久噜噜噜久久久| 欧美洲成人男女午夜视频| 97涩涩爰在线观看亚洲| 成人免费黄色网| 亚洲欧美日韩网| 欧美日韩在线另类| 久久精品人人做人人爽| 欧美激情视频在线观看| 国产精品九九九| 亚洲精品国产精品乱码不99按摩| 欧美日韩亚洲视频| 久久人人看视频| 成人激情视频在线播放| 亚洲欧美精品一区二区| 欧美一区二粉嫩精品国产一线天| 大胆人体色综合| 91精品视频免费观看| 国产精品久久久久久久久久久久| 国产精品久久久久久久久影视| 色悠悠久久久久| 成人午夜激情网| 国产亚洲一区二区精品| 北条麻妃99精品青青久久| www.日韩视频| 日韩欧美国产中文字幕| 日韩免费av片在线观看| 亚洲天堂精品在线| 日韩成人在线播放| 两个人的视频www国产精品| 亚洲国产成人爱av在线播放| 亚洲女人天堂成人av在线| 久久亚洲影音av资源网| 色哟哟入口国产精品| 国产精品尤物福利片在线观看| 国产精品第一视频| 国产亚洲精品日韩| 国产乱肥老妇国产一区二| 日韩在线精品视频| 美女啪啪无遮挡免费久久网站| 国产一区二区三区在线免费观看| 日韩欧美亚洲范冰冰与中字| 久久99久国产精品黄毛片入口| 日韩免费在线观看视频| 国产精品白丝jk喷水视频一区| 亚洲精品资源在线| 欧美一级视频在线观看| 精品国产户外野外| 精品国产成人av| 亚洲变态欧美另类捆绑| 欧美xxxx18国产| 亚洲一区二区在线播放| 日本19禁啪啪免费观看www| 日韩中文字幕网| 亚洲精品网址在线观看| 国产精品盗摄久久久| 国产精品美女久久久久久免费| 久久精品国产视频| 欧美小视频在线| 欧美日韩福利视频| 精品国模在线视频| 最近2019中文字幕mv免费看| 8x拔播拔播x8国产精品| 国产精品吊钟奶在线| 欧美激情va永久在线播放| 精品国产成人av| 国产精品九九九| 国产成人久久精品| 国产一区二区三区视频| 成人在线激情视频| 91欧美激情另类亚洲| 亚洲国模精品一区| 欧美肥老太性生活视频| 成人黄色av免费在线观看| 欧美日韩国产一区中文午夜| 成人美女av在线直播| 国外成人在线播放| 日本精品va在线观看| 97热精品视频官网| 青草青草久热精品视频在线观看| 成人av.网址在线网站| 国产精品草莓在线免费观看| 成人精品视频久久久久| 狠狠久久五月精品中文字幕| 91精品国产自产在线观看永久| 国产日韩精品在线| 日本一区二区三区四区视频| 国产精品激情av电影在线观看| 91av网站在线播放| y97精品国产97久久久久久| 日韩在线视频免费观看高清中文| 亚洲色图色老头| 国产亚洲欧洲高清一区| 日韩在线观看网站| 久久免费精品视频| 久久国产一区二区三区| 日韩av网站大全| 日韩中文字幕在线精品| 激情亚洲一区二区三区四区|