国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

常用的 JS 排序算法 整理版

來源:懂視網 責編:小采 時間:2020-11-27 22:17:05
文檔

常用的 JS 排序算法 整理版

常用的 JS 排序算法 整理版:1.冒泡排序 var bubbleSort = function(arr) { for (var i = 0, len = arr.length; i < len - 1; i++) { for (var j = i + 1; j < len; j++) { if (arr[i] > arr[j]) { var temp = arr[
推薦度:
導讀常用的 JS 排序算法 整理版:1.冒泡排序 var bubbleSort = function(arr) { for (var i = 0, len = arr.length; i < len - 1; i++) { for (var j = i + 1; j < len; j++) { if (arr[i] > arr[j]) { var temp = arr[

1.冒泡排序

var bubbleSort = function(arr) {

 for (var i = 0, len = arr.length; i < len - 1; i++) {
 for (var j = i + 1; j < len; j++) {
 if (arr[i] > arr[j]) {
 var temp = arr[i];
 arr[i] = arr[j];
 arr[j] = temp;
 }
 }
 }

 return arr;
};

2.選擇排序

var selectSort = function(arr) {

 var min;
 for (var i = 0; i < arr.length - 1; i++) {
 min = i;
 for (var j = i + 1; j < arr.length; j++) {
 if (arr[min] > arr[j]) {
 min = j;
 }
 }
 if (i != min) {
 swap(arr, i, min);
 }
 console.log(i + 1, ": " + arr);
 }
 return arr;
};

function swap(arr, index1, index2) {
 var temp = arr[index1];
 arr[index1] = arr[index2];
 arr[index2] = temp;
};

3.插入排序

var insertSort = function(arr) {
 var len = arr.length,
 key;
 for (var i = 1; i < len; i++) {
 var j = i;
 key = arr[j];
 while (--j > -1) {
 if (arr[j] > key) {
 arr[j + 1] = arr[j];
 } else {
 break;
 }
 }
 arr[j + 1] = key;
 }
 return arr;
};

4.希爾排序

function shellSort(arr) {
 if (arr.length < 2) {
 return arr;
 };
 var n = arr.length;
 for (gap = Math.floor(n / 2); gap > 0; gap = Math.floor(gap /= 2)) {
 for (i = gap; i < n; ++i) {
 for (j = i - gap; j >= 0 && arr[j + gap] < arr[j]; j -= gap) {
 temp = arr[j];
 arr[j] = arr[j + gap];
 arr[j + gap] = temp;
 }
 }
 }
 return arr;
};

5.歸并排序

function merge(left, right) {
 var result = [];
 while (left.length > 0 && right.length > 0) {
 if (left[0] < right[0]) {
 // shift()方法用于把數組的第一個元素從其中刪除,并返回第一個元素的值
 result.push(left.shift());
 } else {
 result.push(right.shift());
 }
 }
 return result.concat(left).concat(right);
}

function mergeSort(arr) {
 if (arr.length == 1) {
 return arr;
 }
 var middle = Math.floor(arr.length / 2),
 left = arr.slice(0, middle),
 right = arr.slice(middle);
 return merge(mergeSort(left), mergeSort(right));
}

6.快速排序

var quickSort = function(arr) {  
 if (arr.length <= 1) {
 return arr;
 }

 var pivotIndex = Math.floor(arr.length / 2); 
 var pivot = arr.splice(pivotIndex, 1)[0];

 var left = [];
 var right = [];  
 for (var i = 0; i < arr.length; i++) {   
 if (arr[i] < pivot) {      
 left.push(arr[i]);    
 } else {      
 right.push(arr[i]);    
 } 
 }  
 return quickSort(left).concat([pivot], quickSort(right));

}; 

算法效率比較

---------------------------------------------------------------
| 排序算法 | 平均情況         | 最好情況   | 最壞情況   | 穩定性 |
---------------------------------------------------------------
| 冒泡排序 |  O(n²)          |  O(n)     |  O(n²)    | 穩定   |
---------------------------------------------------------------
| 選擇排序 |  O(n²)          |  O(n²)    |  O(n²)    | 不穩定 |
---------------------------------------------------------------
| 插入排序 |  O(n²)          |  O(n)     |  O(n²)    | 穩定   |
---------------------------------------------------------------
| 希爾排序 |  O(nlogn)~O(n²) |  O(n^1.5) |  O(n²)    | 不穩定 |
---------------------------------------------------------------
| 歸并排序 |  O(nlogn)       |  O(nlogn) |  O(nlogn) | 穩定   |
---------------------------------------------------------------
| 快速排序 |  O(nlogn)       |  O(nlogn) |  O(n²)    | 不穩定 |
---------------------------------------------------------------

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

常用的 JS 排序算法 整理版

常用的 JS 排序算法 整理版:1.冒泡排序 var bubbleSort = function(arr) { for (var i = 0, len = arr.length; i < len - 1; i++) { for (var j = i + 1; j < len; j++) { if (arr[i] > arr[j]) { var temp = arr[
推薦度:
標簽: 整理 js 排序
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产成人a∨麻豆精品 | 亚洲精品免费在线 | 日韩精品一区二区三区 在线观看 | 国产第一夜 | 国产极品视频 | 久操精品在线观看 | 亚洲精品社区 | 国产美女一级毛片 | 免费国产最新进精品视频 | 久久国产精品免费一区二区三区 | 国产真实乱人视频在线看 | 日韩 亚洲 欧美 中文 高清 | 纯毛片| 亚洲欧美在线观看视频 | 自拍偷拍 欧美日韩 | 国产一区二区网站 | 一区二区三区免费在线观看 | 日韩在线1| 国产一区在线视频 | 91视频国产91久久久 | 国产高清精品一级毛片 | 成人日韩 | 国产免费网 | 亚洲伊人天堂 | 日韩综合在线视频 | 国产高清美女一级a毛片久久 | 中文字幕一区二区三区在线观看 | 欧美激情91| 欧美日韩一区二区在线 | 亚洲 欧美 日韩 在线 | 国产美女一级特黄毛片 | 欧美极品第1页专区 | 欧美日韩大片 | 精品国产91久久久久久久 | 欧美性xxxxxx性 | 欧美激情91| 香蕉视频在线免费看 | 国产不卡在线 | 久久99精品国产99久久 | 永久免费毛片 | 成人免费一级毛片在线播放视频 |