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

首頁 > 語言 > JavaScript > 正文

JS實現隨機化快速排序的實例代碼

2024-05-06 15:49:43
字體:
來源:轉載
供稿:網友
這篇文章介紹了JS實現隨機化快速排序的實例代碼,有需要的朋友可以參考一下

算法的平均時間復雜度為O(nlogn)。但是當輸入是已經排序的數組或幾乎排好序的輸入,時間復雜度卻為O(n^2)。為解決這一問題并保證平均時間復雜度為O(nlogn)的方法是引入預處理步驟,它惟一的目的是改變元素的順序使之隨機排序。這種預處理步驟可在O(n)時間內運行。能夠起到同樣作用的另一種簡單方法是在算法中引入一個隨機元素,這可以通過隨機地選擇拆分元素的主元來實現。隨機選擇主元的結果放寬了關于輸入元素的所有排列的可能性相同的步驟。引入這一步來修正原先的快速排序,可得到下面所示的隨機化快速排序。新算法只是在區間[low…high]中一致隨機地選擇一個索引v,并將A[v]和A[low]交換,然后按照原來的快速排序算法繼續。這里,parseInt(Math.random()*(high-low+1) + low)返回一個在low和high之間的數。

復制代碼 代碼如下:

  
/****************************************
  算法:split
  輸入:數組A[low...high]
  輸出:
  1.若有必要,輸出按上述描述的重新排列的數組A;
  2.劃分元素A[low]的新位置w;
  ****************************************/
  function split(array, low, high) {
  var i = low;
  var x = array[low];
  for(var j = low + 1; j <= high; j++) {
  if(array[j] <= x) {
  i ++;
  if(i != j) {
  var temp = array[i];
  array[i] = array[j];
  array[j] = temp;
  }
  }
  }
  temp = array[low];
  array[low] = array[i];
  array[i] = temp;
  return i;
  }
  /****************************************
  算法:rquicksort
  輸入:A[0...n-1]
  輸出:按非降序排列數組A[0...n-1]
  rquicksort(A, 0, n-1);
  ****************************************/
  function rquicksort(array, low, high) {
  if(low < high) {
  /******隨機化拆分元素的主元*******/
  var v = parseInt(Math.random()*(high-low+1) + low);
  var tmp = array[low];
  array[low] = array[v];
  array[v] = tmp;
  /******隨機化拆分元素的主元*******/
  var w = split(array, low, high);
  rquicksort(array, low, w -1);
  rquicksort(array, w +1, high);
  return array;
  }
  }
  var array = [33, 22, 11, 88, 23, 32];
  array = rquicksort(array, 0, array.length-1);
  console.log(array);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 长沙县| 昔阳县| 三穗县| 获嘉县| 甘肃省| 孙吴县| 通河县| 荃湾区| 马边| 广东省| 体育| 遂平县| 同德县| 鄂尔多斯市| 闵行区| 尚志市| 望奎县| 麦盖提县| 浮山县| 镶黄旗| 海阳市| 荥经县| 柏乡县| 德庆县| 夏津县| 三都| 黑河市| 兴宁市| 昭平县| 阜康市| 尼勒克县| 潮州市| 隆德县| 河东区| 平罗县| 都兰县| 武邑县| 惠东县| 米易县| 黔南| 汽车|