冒泡排序
重复地访问过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
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.lengthif (len < 2) {return arr}var middle = Math.floor(len / 2);var left = arr.splice(0, middle);var right = arrreturn 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]))
