pengzhanbo
281字小于1分钟
2022-04-25
提问
归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为2-路归并。
function mergeSort(arr) {
if (!Array.isArray(arr) || arr.length <= 1) return arr
const len = arr.length
const middle = parseInt(len >> 1)
const left = arr.slice(0, middle)
const right = arr.slice(middle, len)
return merge(mergeSort(left), mergeSort(right))
}
function merge(left, right) {
const result = []
const leftLen = left.length
const rightLen = right.length
let il = 0
let ir = 0
while (il < leftLen && ir < rightLen) {
if (left[il] < right[ir]) {
result.push(left[il++])
} else {
result.push(right[ir++])
}
}
while (il < leftLen) {
result.push(left[il++])
}
while (ir < rightLen) {
result.push(right[ir++])
}
return result
}