JS實現(xiàn)隨機化快速排序的實例代碼
更新時間:2013年08月01日 16:47:24 作者:
這篇文章介紹了JS實現(xiàn)隨機化快速排序的實例代碼,有需要的朋友可以參考一下
算法的平均時間復(fù)雜度為O(nlogn)。但是當輸入是已經(jīng)排序的數(shù)組或幾乎排好序的輸入,時間復(fù)雜度卻為O(n^2)。為解決這一問題并保證平均時間復(fù)雜度為O(nlogn)的方法是引入預(yù)處理步驟,它惟一的目的是改變元素的順序使之隨機排序。這種預(yù)處理步驟可在O(n)時間內(nèi)運行。能夠起到同樣作用的另一種簡單方法是在算法中引入一個隨機元素,這可以通過隨機地選擇拆分元素的主元來實現(xiàn)。隨機選擇主元的結(jié)果放寬了關(guān)于輸入元素的所有排列的可能性相同的步驟。引入這一步來修正原先的快速排序,可得到下面所示的隨機化快速排序。新算法只是在區(qū)間[low…h(huán)igh]中一致隨機地選擇一個索引v,并將A[v]和A[low]交換,然后按照原來的快速排序算法繼續(xù)。這里,parseInt(Math.random()*(high-low+1) + low)返回一個在low和high之間的數(shù)。
/****************************************
算法: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) {
/******隨機化拆分元素的主元*******/
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);
復(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) {
/******隨機化拆分元素的主元*******/
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);
您可能感興趣的文章:
相關(guān)文章
學(xué)習JavaScript設(shè)計模式(封裝)
這篇文章主要帶領(lǐng)大家學(xué)習JavaScript設(shè)計模式,其中重點介紹封裝,舉例說明封裝的思想,對封裝進行詳細剖析,感興趣的小伙伴們可以參考一下2015-11-11javascript ES6 Template String模板字符串使用方法
這篇文章主要介紹了javascript ES6 模板字符串(Template String)是增強版的字符串,用反引號(`)標識,它可以當作普通字符串使用,也可以用來定義多行字符串,或者在字符串中嵌入變量,需要的朋友可以參考下2023-06-06微信小程序向Java后臺傳輸參數(shù)的方法實現(xiàn)
這篇文章主要介紹了微信小程序向Java后臺傳輸參數(shù)的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2020-12-12(跨瀏覽器基礎(chǔ)事件/瀏覽器檢測/判斷瀏覽器)經(jīng)驗代碼分享
一些js代碼,自己備用的,高手不要笑話我。(跨瀏覽器基礎(chǔ)事件,瀏覽器檢測,判斷瀏覽器的名稱、版本號、操作系統(tǒng))等等,很實用的,方便自己使用,感興趣的朋友可以了解下,希望本文對你有所幫助2013-01-01