欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實(shí)現(xiàn)隨機(jī)化快速排序的實(shí)例代碼

 更新時(shí)間:2013年08月01日 16:47:24   作者:  
這篇文章介紹了JS實(shí)現(xiàn)隨機(jī)化快速排序的實(shí)例代碼,有需要的朋友可以參考一下
算法的平均時(shí)間復(fù)雜度為O(nlogn)。但是當(dāng)輸入是已經(jīng)排序的數(shù)組或幾乎排好序的輸入,時(shí)間復(fù)雜度卻為O(n^2)。為解決這一問題并保證平均時(shí)間復(fù)雜度為O(nlogn)的方法是引入預(yù)處理步驟,它惟一的目的是改變元素的順序使之隨機(jī)排序。這種預(yù)處理步驟可在O(n)時(shí)間內(nèi)運(yùn)行。能夠起到同樣作用的另一種簡單方法是在算法中引入一個(gè)隨機(jī)元素,這可以通過隨機(jī)地選擇拆分元素的主元來實(shí)現(xiàn)。隨機(jī)選擇主元的結(jié)果放寬了關(guān)于輸入元素的所有排列的可能性相同的步驟。引入這一步來修正原先的快速排序,可得到下面所示的隨機(jī)化快速排序。新算法只是在區(qū)間[low…h(huán)igh]中一致隨機(jī)地選擇一個(gè)索引v,并將A[v]和A[low]交換,然后按照原來的快速排序算法繼續(xù)。這里,parseInt(Math.random()*(high-low+1) + low)返回一個(gè)在low和high之間的數(shù)。
復(fù)制代碼 代碼如下:
  
/****************************************
  算法:split
  輸入:數(shù)組A[low...high]
  輸出:
  1.若有必要,輸出按上述描述的重新排列的數(shù)組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]
  輸出:按非降序排列數(shù)組A[0...n-1]
  rquicksort(A, 0, n-1);
  ****************************************/
  function rquicksort(array, low, high) {
  if(low < high) {
  /******隨機(jī)化拆分元素的主元*******/
  var v = parseInt(Math.random()*(high-low+1) + low);
  var tmp = array[low];
  array[low] = array[v];
  array[v] = tmp;
  /******隨機(jī)化拆分元素的主元*******/
  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);

相關(guān)文章

  • javascript函數(shù)式編程程序員的工具集

    javascript函數(shù)式編程程序員的工具集

    函數(shù)式編程語言一向被認(rèn)為是比其它編程語言更高深的語言。一是因?yàn)楹瘮?shù)式編程語言的語法很另類,比如Lisp語言,二是因?yàn)楹瘮?shù)式編程語言都很古老,比如Schema語言。在如今面向?qū)ο笳Z言大行其道的時(shí)代,函數(shù)式編程語言有其特殊的優(yōu)勢
    2015-10-10
  • 微信小程序?qū)崿F(xiàn)時(shí)間預(yù)約功能

    微信小程序?qū)崿F(xiàn)時(shí)間預(yù)約功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)時(shí)間預(yù)約基本功能,一個(gè)類似電商的時(shí)間預(yù)約功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 學(xué)習(xí)JavaScript設(shè)計(jì)模式(封裝)

    學(xué)習(xí)JavaScript設(shè)計(jì)模式(封裝)

    這篇文章主要帶領(lǐng)大家學(xué)習(xí)JavaScript設(shè)計(jì)模式,其中重點(diǎn)介紹封裝,舉例說明封裝的思想,對(duì)封裝進(jìn)行詳細(xì)剖析,感興趣的小伙伴們可以參考一下
    2015-11-11
  • vue 自定義指令directive的使用場景

    vue 自定義指令directive的使用場景

    這篇文章主要詳細(xì)介紹了vue 自定義指令directive的使用場景,文中有詳細(xì)的代碼示例,感興趣的小伙伴歡迎閱讀
    2023-04-04
  • javascript ES6 Template String模板字符串使用方法

    javascript ES6 Template String模板字符串使用方法

    這篇文章主要介紹了javascript ES6 模板字符串(Template String)是增強(qiáng)版的字符串,用反引號(hào)(`)標(biāo)識(shí),它可以當(dāng)作普通字符串使用,也可以用來定義多行字符串,或者在字符串中嵌入變量,需要的朋友可以參考下
    2023-06-06
  • 微信小程序判斷用戶是否需要再次授權(quán)獲取個(gè)人信息

    微信小程序判斷用戶是否需要再次授權(quán)獲取個(gè)人信息

    這篇文章主要介紹了微信小程序判斷用戶是否需要再次授權(quán)獲取個(gè)人信息,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 給網(wǎng)頁加個(gè)彩色窗口

    給網(wǎng)頁加個(gè)彩色窗口

    給網(wǎng)頁加個(gè)彩色窗口...
    2006-07-07
  • 基于Javascript倒計(jì)時(shí)效果

    基于Javascript倒計(jì)時(shí)效果

    這篇文章主要為大家詳細(xì)介紹了基于Javascript倒計(jì)時(shí)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 微信小程序向Java后臺(tái)傳輸參數(shù)的方法實(shí)現(xiàn)

    微信小程序向Java后臺(tái)傳輸參數(shù)的方法實(shí)現(xiàn)

    這篇文章主要介紹了微信小程序向Java后臺(tái)傳輸參數(shù)的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • (跨瀏覽器基礎(chǔ)事件/瀏覽器檢測/判斷瀏覽器)經(jīng)驗(yàn)代碼分享

    (跨瀏覽器基礎(chǔ)事件/瀏覽器檢測/判斷瀏覽器)經(jīng)驗(yàn)代碼分享

    一些js代碼,自己備用的,高手不要笑話我。(跨瀏覽器基礎(chǔ)事件,瀏覽器檢測,判斷瀏覽器的名稱、版本號(hào)、操作系統(tǒng))等等,很實(shí)用的,方便自己使用,感興趣的朋友可以了解下,希望本文對(duì)你有所幫助
    2013-01-01

最新評(píng)論