国产探花免费观看_亚洲丰满少妇自慰呻吟_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);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 维西| 年辖:市辖区| 乐山市| 丰顺县| 随州市| 南阳市| 德格县| 太和县| 宣武区| 罗源县| 韩城市| 三亚市| 曲麻莱县| 竹溪县| 徐闻县| 革吉县| 精河县| 奎屯市| 永安市| 延长县| 东辽县| 科技| 溆浦县| 白城市| 双桥区| 陕西省| 牡丹江市| 宾川县| 阿勒泰市| 深水埗区| 沈丘县| 宁波市| 滁州市| 溧阳市| 长子县| 大名县| 保靖县| 临洮县| 德兴市| 富顺县| 麦盖提县|