


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第JavaScript實(shí)現(xiàn)快速排序的方法分析本文實(shí)例講述了JavaScript實(shí)現(xiàn)快速排序的方法。分享給大家供大家參考,具體如下:
思想:
通過分治思想、遞歸方法將數(shù)據(jù)依次分解為包含較小元素和較大元素的不同子序列
1.在數(shù)組中選擇一個(gè)元素為基準(zhǔn)
2.對(duì)數(shù)組進(jìn)行遍歷,小于基準(zhǔn)的元素都移到基準(zhǔn)的左邊,大于基準(zhǔn)的元素都移到基準(zhǔn)的右邊
3.對(duì)基準(zhǔn)左邊和右邊的兩個(gè)子集,不斷重復(fù)前兩步,直到所有子集只剩下一個(gè)元素為止
實(shí)現(xiàn)代碼:
functionsqort(arr){
if(arr.length===0){
return[];
varleft=[];
varright=[];
varpivot=arr[0];//(基準(zhǔn)以首元素)
for(vari=1;iarr.length;i++){
if(arr[i]pivot){
left.push(arr[i]);
}else{
right.push(arr[i]);
returnsqort(left).concat(pivot,qsort(right));//遞歸
vara=[];
for(i=0;i++i){
a[i]=Math.floor(Math.random()*100+1);
console.log(a);
console.log(sqort(a));
//(基準(zhǔn)以中間元素的情況)
functionsqort(arr){
if(arr.length=1){
returnarr;
varleft=[];
varright=[];
varpivotIndex=Math.floor(arr.length/2);
varpivot=arr.splice(pivotIndex,1)[0];//(基準(zhǔn)以中間元素)
for(vari=1;iarr.length;i++){
if(arr[i]pivot){
left.push(arr[i]);
}else{
right.push(arr[i]);
returnsqort(left).concat(pivot,sqort(right));//遞歸
vara=[12,34,23,78,34,26];
console.log(a);
console.log(sqort(a));
注:對(duì)于較小數(shù)組和較大數(shù)組分別遞歸調(diào)用sqort()函數(shù),當(dāng)遞歸結(jié)束時(shí)候,再將較小的數(shù)組與基準(zhǔn)以及較大的數(shù)組連接起來形成最終的有序數(shù)組并返回。
PS:這里再為大家推薦一款關(guān)于排序的演示工具供大家參考:
在線動(dòng)畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具:
/aideddesign/paixu_ys
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《Java
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年歷史文化街區(qū)保護(hù)與城市更新社區(qū)共建共享研究報(bào)告
- 生態(tài)休閑農(nóng)業(yè)園項(xiàng)目可行性研究報(bào)告-立項(xiàng)書
- 電氣作業(yè)復(fù)習(xí)測(cè)試題
- 2025年工業(yè)互聯(lián)網(wǎng)平臺(tái)網(wǎng)絡(luò)流量整形技術(shù)在工業(yè)控制系統(tǒng)穩(wěn)定性中的應(yīng)用報(bào)告
- 資產(chǎn)證券化AI應(yīng)用行業(yè)跨境出海項(xiàng)目商業(yè)計(jì)劃書
- 高效空氣壓縮機(jī)租賃企業(yè)制定與實(shí)施新質(zhì)生產(chǎn)力項(xiàng)目商業(yè)計(jì)劃書
- 生物信息學(xué)服務(wù)行業(yè)跨境出海項(xiàng)目商業(yè)計(jì)劃書
- 電動(dòng)觀光車服務(wù)行業(yè)跨境出海項(xiàng)目商業(yè)計(jì)劃書
- 創(chuàng)意市集與文化交流平臺(tái)企業(yè)制定與實(shí)施新質(zhì)生產(chǎn)力項(xiàng)目商業(yè)計(jì)劃書
- 稀有金屬精密加工服務(wù)行業(yè)跨境出海項(xiàng)目商業(yè)計(jì)劃書
- 別墅清包工合同協(xié)議書
- DL∕T 1297-2013 電能質(zhì)量監(jiān)測(cè)系統(tǒng)技術(shù)規(guī)范
- 高考英語688高頻詞匯excel版
- 預(yù)制混凝土蓋板合同范本
- 雙小齒輪助力式電動(dòng)轉(zhuǎn)向器技術(shù)要求及試驗(yàn)方法
- 基礎(chǔ)有機(jī)化學(xué)實(shí)驗(yàn)智慧樹知到期末考試答案章節(jié)答案2024年浙江大學(xué)
- (高清版)JCT 864-2008 聚合物乳液建筑防水涂料
- ZXB∕T 0202-2013 球墨鑄鐵給排水管道工程施工及驗(yàn)收規(guī)范 技術(shù)要求
- 老年專科護(hù)理考試試題
- 語法大全之一般現(xiàn)在時(shí)動(dòng)詞三單變化練習(xí)題-(答案)
- 建筑保溫工程包工包料合同協(xié)議書范本
評(píng)論
0/150
提交評(píng)論