JavaScirpt基础-数组排序之归并排序

简介: 归并排序

归并排序(Merge sort)是建立在归并操作上的一种有效的排序算法。

该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。

将已有序的子序列合并,得到完全有序的序列;

先使每个子序列有序,再使子序列段间有序。

若将两个有序表合并成一个有序表,称为二路归并。

var a = [1, 3, 8, 6, 15, 3, 4, 23, 76, , 34, 232, 6, 9, 456, 221];

function mergeSort(array) {

const merge = (right, left) => {

const result = []

let il = 0

let ir = 0

while (il < left.length && ir < right.length) {

  if (left[il] < right[ir]) {

    result.push(left[il++])

  } else {

    result.push(right[ir++])

  }

}

while (il < left.length) {

  result.push(left[il++])

}

while (ir < right.length) {

  result.push(right[ir++])

}

return result

}

const mergeSort = array => {

if (array.length === 1) { return array }

const mid = Math.floor(array.length / 2)

const left = array.slice(0, mid)

const right = array.slice(mid, array.length)

return merge(mergeSort(left), mergeSort(right))

}

return mergeSort(array)

}

mergeSort(a); // [, 1, 3, 3, 4, 6, 6, 8, 9, 15, 23, 34, 76, 221, 232, 456]

目录
相关文章
|
5月前
|
算法
桶排序(简化版)与冒泡排序
桶排序(简化版)与冒泡排序
32 0
|
存储 算法 搜索推荐
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)2
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)2
235 0
|
5月前
|
搜索推荐 算法
常见排序算法以及冒泡排序的基础使用方法
常见排序算法以及冒泡排序的基础使用方法
32 0
|
5月前
|
JavaScript 搜索推荐 前端开发
JS数组自定义排序方法,冒泡排序、插入排序、选择排序和快速排序。
JS数组自定义排序方法,冒泡排序、插入排序、选择排序和快速排序。
62 0
|
算法 搜索推荐 Shell
Shell编程之数组排序算法(冒泡排序、直接选择排序、反转排序)
1、数组排序(使用tr、sort、for) 操作步骤; 使用tr命令将数组内每个元素之间的空格替换为换行符; 之后使用sort命令按从小到大重新排序; 最后使用for循环遍历排序后的元素值。
452 0
|
存储 算法 搜索推荐
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)1
数据结构各内部排序算法总结对比及动图演示(插入排序、冒泡和快速排序、选择排序、堆排序、归并排序和基数排序等)1
173 0
|
搜索推荐 算法
|
搜索推荐 索引