冒泡排序
重复地访问过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
var arr = [3, 4, 1, 2];
function bubbleSort2(arr) {
for (var j = 0; j < arr.length - 1; j++) {
// 这里要根据外层for循环的 j,逐渐减少内层 for循环的次数
for (var i = 0; i < arr.length - 1 - j; i++) {
if (arr[i] > arr[i + 1]) {
[arr[i] ,arr[i + 1]] = [arr[i + 1], arr[i]];
}
}
}
return arr;
}
选择排序
首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
function SelectSort(arr){
let minIndex;
for(let i = 0; i < arr.length; i++){
minIndex = i;
for(let j = i + 1; j < arr.length; j++){
if(arr[j] < arr[minIndex]){
minIndex = j
}
}
[arr[minIndex], arr[i]] = [arr[i], arr[minIndex]]
}
return arr
}
console.log(SelectSort([4,1,2,4,7,89,3,2]))
插入排序
通过构建有序序列,对于未排序数据,在已排序序列中从后向扫描
function insertSort(arr){
for(let i = 1; i < arr.length; i++){
let key = arr[i];
let j = i - 1;
while(j >= 0 && arr[j] > key){
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
return arr
}
console.log(insertSort([4,1,2,4,7,89,3,2]))
归并排序
采用分治法,将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为2-路归并。
function mergeSort(arr) {
var len = arr.length
if (len < 2) {
return arr
}
var middle = Math.floor(len / 2);
var left = arr.splice(0, middle);
var right = arr
return merge(mergeSort(left), mergeSort(right));
}
function merge(left, right) {
var result = [];
while (left.length && right.length) {
if(left[0] <= right[0]) {
result.push(left.shift())
} else {
result.push(right.shift());
}
}
return result.concat(left, right);
}
console.log(mergeSort([4,1,2,4,7,89,3,2]))
快速排序
通过一趟排序将待拍记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。
function quickSort(arr){
if(arr.length <= 1){
return arr;
}
let pivotIndex = Math.floor(arr.length / 2);
let pivot = arr.splice(pivotIndex, 1)[0];
let left = [];
let right = [];
for(let i = 0; i < arr.length; i++){
if(arr[i] < pivot){
left.push(arr[i]);
} else {
right.push(arr[i])
}
}
return [...quickSort(left), pivot, ...quickSort(right)];
}
console.log(quickSort([4,1,2,4,7,89,3,2]))