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

首頁 > 編程 > JavaScript > 正文

Javascript堆排序算法詳解

2019-11-20 13:49:46
字體:
來源:轉載
供稿:網友

堆排序分為兩個過程:

1.建堆。

堆實質上是完全二叉樹,必須滿足:樹中任一非葉子結點的關鍵字均不大于(或不小于)其左右孩子(若存在)結點的關鍵字。

堆分為:大根堆和小根堆,升序排序采用大根堆,降序排序采用小根堆。

如果是大根堆,則通過調整函數將值最大的節點調整至堆根。

2.將堆根保存于尾部,并對剩余序列調用調整函數,調整完成后,再將最大跟保存于尾部-1(-1,-2,...,-i),再對剩余序列進行調整,反復進行該過程,直至排序完成。

復制代碼 代碼如下:

//調整函數
function headAdjust(elements, pos, len){
  //將當前節點值進行保存
  var swap = elements[pos];
  //定位到當前節點的左邊的子節點
  var child = pos * 2 + 1;
  //遞歸,直至沒有子節點為止
  while(child < len){
    //如果當前節點有右邊的子節點,并且右子節點較大的場合,采用右子節點
    //和當前節點進行比較
    if(child + 1 < len && elements[child] < elements[child + 1]){
      child += 1;
    }
    //比較當前節點和最大的子節點,小于則進行值交換,交換后將當前節點定位
    //于子節點上
    if(elements[pos] < elements[child]){
      elements[pos] = elements[child];
      pos = child;
      child = pos * 2 + 1;
    }
    else{
      break;
    }
    elements[pos] = swap;
  }
}
//構建堆
function buildHeap(elements){
  //從最后一個擁有子節點的節點開始,將該節點連同其子節點進行比較,
  //將最大的數交換與該節點,交換后,再依次向前節點進行相同交換處理,
  //直至構建出大頂堆(升序為大頂,降序為小頂)
  for(var i=elements.length/2; i>=0; i--){
    headAdjust(elements, i, elements.length);
  }
}
function sort(elements){
  //構建堆
  buildHeap(elements);
  //從數列的尾部開始進行調整
  for(var i=elements.length-1; i>0; i--){
    //堆頂永遠是最大元素,故,將堆頂和尾部元素交換,將
    //最大元素保存于尾部,并且不參與后面的調整
    var swap = elements[i];
    elements[i] = elements[0];
    elements[0] = swap;
    //進行調整,將最大)元素調整至堆頂
    headAdjust(elements, 0, i);
  }
}
var elements = [3, 1, 5, 7, 2, 4, 9, 6, 10, 8];
console.log('before: ' + elements);
sort(elements);
console.log(' after: ' + elements);

效率:

時間復雜度:最好:O(nlog2n),最壞:O(nlog2n),平均:O(nlog2n)。

空間復雜度:O(1)。

穩定性:不穩定

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91欧美精品午夜性色福利在线| 亚洲欧美精品一区| 欧美精品九九久久| 日韩欧美在线观看视频| 久久久国产精彩视频美女艺术照福利| 久久免费精品日本久久中文字幕| 国产国语videosex另类| 亚洲欧洲视频在线| 欧美视频在线免费| 91免费综合在线| 综合136福利视频在线| 国产高清视频一区三区| 日韩av免费网站| 色午夜这里只有精品| 亚洲欧美成人在线| 黄色成人在线播放| 美女视频黄免费的亚洲男人天堂| 亚洲免费高清视频| 国产成+人+综合+亚洲欧美丁香花| 日本亚洲欧美成人| 亚洲香蕉成人av网站在线观看| 久久精品2019中文字幕| 日韩欧美精品免费在线| 欧美亚洲国产日本| 91国偷自产一区二区三区的观看方式| 亚洲国产欧美在线成人app| 91久久久久久| 91久久精品视频| 亚洲一区二区三区在线视频| 91亚洲va在线va天堂va国| 亚洲美女喷白浆| 57pao国产成人免费| 久久精品成人欧美大片古装| 日韩欧美aaa| 国内伊人久久久久久网站视频| 久久精品国产69国产精品亚洲| 69久久夜色精品国产69| 亚洲tv在线观看| 91成人在线观看国产| 91精品啪在线观看麻豆免费| 亚洲女性裸体视频| 亚洲免费人成在线视频观看| 久久免费国产视频| 久久久久女教师免费一区| 日韩成人av在线播放| 3344国产精品免费看| 日韩欧美高清在线视频| 国产成+人+综合+亚洲欧美丁香花| 最好看的2019的中文字幕视频| 久久久久久国产精品美女| 日本精品在线视频| 最新国产成人av网站网址麻豆| 狠狠躁夜夜躁人人爽超碰91| 欧美精品久久一区二区| 成人在线小视频| 国产综合久久久久久| 亚洲视频国产视频| 亚洲丝袜av一区| 欧亚精品中文字幕| 国产视频精品久久久| 欧美性xxxxxxxxx| 久久久久久久激情视频| 色777狠狠综合秋免鲁丝| 亚洲综合精品一区二区| 91精品国产91久久久久久吃药| 国产91精品青草社区| 欧美成人激情在线| 国内精品视频在线| 懂色av中文一区二区三区天美| 成人久久一区二区三区| 中文字幕亚洲在线| 国产精品久久久999| 亚洲精品免费在线视频| 91免费在线视频| 亚洲成色777777女色窝| 国产欧美精品一区二区三区介绍| 欧美精品在线网站| 亚洲第一精品夜夜躁人人躁| 久久国产精品久久国产精品| 国产精品久久久久久久7电影| 亚洲欧美福利视频| 国产精品久久久91| 国产一区二区欧美日韩| 茄子视频成人在线| 亚洲精品99999| 欧美劲爆第一页| 日韩在线视频国产| 久久久99久久精品女同性| 色综合久久88| 日韩av手机在线观看| 久久精品视频一| 欧美怡红院视频一区二区三区| 国产成人a亚洲精品| 国产精品视频永久免费播放| 国产免费一区二区三区香蕉精| 这里只有精品久久| 国产精品www网站| 国产精品精品视频| 国产精品美乳在线观看| 国产999精品久久久| 亚洲国产一区自拍| 日韩精品免费观看| 欧美中文字幕精品| 黄色一区二区在线| 亚洲人成绝费网站色www| 69av成年福利视频| 久久久999精品免费| 91久久国产精品91久久性色| 全亚洲最色的网站在线观看| 久久久av一区| 亚洲成人教育av| 国产亚洲精品激情久久| 久久6免费高清热精品| 亚洲精品自在久久| 日韩美女视频免费在线观看| 国产精品色婷婷视频| 欧美成人精品在线观看| 色妞久久福利网| 亚洲精品国产综合久久| 亚洲欧美日韩国产中文| 欧美激情视频在线| 国产+成+人+亚洲欧洲| 日韩欧美黄色动漫| 国产精品国产三级国产aⅴ9色| 欧美性xxxxx极品| 日韩激情在线视频| 国产日产欧美a一级在线| 亚洲一级免费视频| 中文字幕精品国产| 激情av一区二区| 国产精品成人国产乱一区| 日韩精品中文字幕久久臀| 亚洲激情成人网| 97av在线视频免费播放| 精品福利一区二区| 亚洲在线视频观看| 尤物yw午夜国产精品视频明星| 欧美激情精品在线| 九九久久精品一区| 日本久久久久久久久久久| 性欧美xxxx视频在线观看| 欧美日韩国产黄| 国产成人精品在线| 亚洲国产成人精品电影| 亚洲自拍偷拍视频| 亚洲成人久久电影| 国产精品18久久久久久麻辣| 91精品国产高清| 亚洲韩国欧洲国产日产av| 亚洲电影av在线| 国产丝袜精品第一页| 成人福利视频网| 午夜精品久久久久久久99热| 这里只有精品在线观看| 亚洲天堂av综合网| 日韩国产中文字幕| 亚洲人午夜色婷婷| 欧美成人精品xxx| 日韩欧美在线免费| 亚洲精品理论电影| 中文字幕一区二区精品| 日韩精品中文字| www国产精品视频| 国产精品普通话|