美文网首页
排序 -- 2

排序 -- 2

作者: YangJeremy | 来源:发表于2018-03-30 15:21 被阅读0次

插入排序

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;
};



相关文章

  • android 随笔之排序算法

    1,冒泡排序(1) 冒泡排序(2) 2,选择排序 3,插入排序 4,快速排序

  • MySQL学习:DQL:查询语句

    1、排序查询 ORDER BY 排序字段1 排序方式1,排序字段2 排序方式2; 排序方式: ASC:升序,默认的...

  • [Haskell] 一些常见的排序算法

    1. 排序算法 (1)选择排序 (2)插入排序 (3)快速排序 (4)归并排序 (5)堆排序 (6)树排序 2. ...

  • python 八大算法

    排序算法总结 排序算法 平均时间复杂度 冒泡排序O(n2) 选择排序O(n2) 插入排序O(n2) 希尔排序O(n...

  • [算法导论]-第七章-快速排序

    本章重点 1.快速排序 2.冒泡排序 3.希尔排序 1.快速排序 2.冒泡排序 3.希尔排序 希尔排序,也称递减增...

  • js常用的数组排序

    1、冒泡排序 2、选择排序 3、桶排序 4、sort排序

  • 算法-排序算法总结

    排序类型总结 1 排序算法基础实现 2 排序算法应用 2.1 基础排序 2.2 计数排序应用 2.3 快排应用 2...

  • 排序算法小总结

    排序算法时间复杂度冒泡排序O(n2)选择排序O(n2)插入排序O(n2)希尔排序O(n1.5)快速排序O(N*lo...

  • 排序

    1、选择排序 2、冒泡排序 3、插入排序 4、快速排序

  • 排序算法

    1冒泡排序 2插入排序 3选择排序 4快速排序

网友评论

      本文标题:排序 -- 2

      本文链接:https://www.haomeiwen.com/subject/lajicftx.html