排序 -- 2

插入排序

this.insertionSort = function () {
    var length = array.length, //{1}
        j, temp;
    for (var i = 1; i < length; i++) { //{2}
        j = i; //{3}
        temp = array[i]; //{4}
        while (j > 0 && array[j - 1] > temp) { //{5}
            array[j] = array[j - 1]; //{6}
            j--;
        }
        array[j] = temp; //{7}
    }
};

归并排序

this.mergeSort = function () {
    array = mergeSortRec(array);
};


var mergeSortRec = function (array) {
    var length = array.length;
    if (length === 1) { //{1}
        return array; //{2}
    }
    var mid = Math.floor(length / 2), //{3}
        left = array.slice(0, mid), //{4}
        right = array.slice(mid, length); //{5}
    return merge(mergeSortRec(left), mergeSortRec(right)); //{6}
};

var merge = function (left, right) {
    var result = [], // {7}
        il = 0,
        ir = 0;
    while (il < left.length && ir < right.length) { // {8}
        if (left[il] < right[ir]) {
            result.push(left[il++]); // {9}
        } else {
            result.push(right[ir++]); // {10}
        }
    }
    while (il < left.length) { // {11}
        result.push(left[il++]);
    }
    while (ir < right.length) { // {12}
        result.push(right[ir++]);
    }
    return result; // {13}
};

快速排序

this.quickSort = function () {
    quick(array, 0, array.length - 1);
};

var quick = function (array, left, right) {
    var index; //{1}
    if (array.length > 1) { //{2}
        index = partition(array, left, right); //{3}
        if (left < index - 1) { //{4}
            quick(array, left, index - 1); //{5}
        }
        if (index < right) { //{6}
            quick(array, index, right); //{7}
        }
    }
};

var partition = function (array, left, right) {
    var pivot = array[Math.floor((right + left) / 2)], //{8}
        i = left, //{9}
        j = right; //{10}
    while (i <= j) { //{11}
        while (array[i] < pivot) { //{12}
            i++;
        }
        while (array[j] > pivot) { //{13}
            j--;
        }
        if (i <= j) { //{14}
            swapQuickStort(array, i, j); //{15}
            i++;
            j--;
        }
    }
    return i; //{16}
};

var swapQuickStort = function (array, index1, index2) {
    var aux = array[index1];
    array[index1] = array[index2];
    array[index2] = aux;
};



©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 接上一篇,这节将回顾两种效率较高的排序方法——归并排序和快速排序。 归并排序 归并排序的思想如图所示。先对整个列表...
    hitsunbo阅读 677评论 0 2
  • 引言 本章记录一些平均时间效率更高的排序算法,他们的时间复杂度通常为O(nlogn)级别,但其实现都比较复杂,所以...
    阿堃堃堃堃阅读 562评论 0 0
  • 1 初级排序算法 排序算法关注的主要是重新排列数组元素,其中每个元素都有一个主键。排序算法是将所有元素主键按某种方...
    深度沉迷学习阅读 1,463评论 0 1
  • 一. 写在前面 要学习算法,“排序”是一个回避不了的重要话题,在分析完并查集算法和常用数据结构之后,今天我们终于可...
    Leesper阅读 2,555评论 0 40
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,286评论 0 2