归并排序归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。值得注意的是归并排序是一种稳定的排序方法。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为2-路归并。算法描述归并操作的工作原理如下:第一步:申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列第二步:设定两个指针,最初位置分别为两个已经排序序列的起始位置第三步:比较两个指针
quickSort-mergeSort-heapSort-radixSort
非递归快速排序归并排序堆排序基数排序的实现
//快速排序
function quickSort ( arr ) {
var parts = [ [ 0 , arr . length - 1 ] ] ;
while ( parts . length ) {
var part = parts . shift ( ) ;
var l = part [ 0 ] ;