国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js快速排序的實現代碼

2019-11-20 21:30:36
字體:
來源:轉載
供稿:網友

但是有不少的書本講得并不是很清楚,而且不同的教材的實現方式也不盡相同,
我這里將最簡單的快速排序的思路寫出來供大家參考。

希望不管是使用什么語言都能從這個簡單的代碼里很方便的掌握快排思路與編寫方式

復制代碼 代碼如下:

function quick_sort(list, start, end) { 
      if (start < end) { 
        var pivotpos = partition(list, start, end);   //找出快排的基數 
        quick_sort(list, start, pivotpos - 1);        //將左邊的快排一次 
        quick_sort(list, pivotpos + 1, end);          //將右邊的快排一次 
      } 
    } 

     
    //將一個序列調整成以基數為分割的兩個區域,一邊全都不小于基數,一邊全都不大于基數 
    function partition(list, start, end) { 
      var pivotpos = start; 
      var pivot = list[start]; 
      var tmp; 
      for(var i = start + 1; i <= end; i ++) { 
        if (list[i] < pivot) { 
          tmp = list[i]; 
          pivotpos += 1; 
          list[i] = list[pivotpos]; 
          list[pivotpos] = tmp; 
        } 
      } 

      tmp = list[start]; 
      list[start] = list[pivotpos]; 
      list[pivotpos] = tmp; 
      return pivotpos; 
    } 

     
    var list = [8,2,4,65,2,4,7,1,9,0,2,34,12]; 

    quick_sort(list, 0, list.length);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 高邮市| 山丹县| 宝坻区| 临沧市| 连江县| 石景山区| 芜湖市| 普定县| 静安区| 得荣县| 阜宁县| 定安县| 和政县| 石河子市| 五家渠市| 望城县| 大名县| 梁河县| 兴文县| 灵山县| 吉安县| 德惠市| 乐昌市| 买车| 巩义市| 钟山县| 嘉义市| 彰武县| 广饶县| 格尔木市| 漾濞| 蒙自县| 宝丰县| 张北县| 南开区| 监利县| 贵定县| 呼图壁县| 乐清市| 苗栗县| 舞阳县|