美文网首页
Javascript快速排序

Javascript快速排序

作者: 丘比特爱上猫 | 来源:发表于2019-01-22 10:30 被阅读11次
  1. 快速排序大众版
var quickSort = function(arr) {
        /**
        |--------------------------------------------------
        | 当arr长度为1时返回
        |--------------------------------------------------
        */
      if (arr.length <= 1) { return arr; }
        /**
        |--------------------------------------------------
        | 选取基准值,我选择第一个值,没必要选择中间的值
        |--------------------------------------------------
        */
        var pivot = arr[0]
        /**
        |--------------------------------------------------
        | 遍历数组,从索引为1开始,索引为0的是我们的基准值,将小于基准值的放在左侧,
        | 大于基准值的放在右侧
        |--------------------------------------------------
        */
        var left = []
        var right = []
        for(var i = 1;i<arr.length;i++){
            if(arr[i] < pivot) {
                left.push(arr[i])
            }else{
                right.push(arr[i])
            }
        }
        /**
        |--------------------------------------------------
        | 递归
        |--------------------------------------------------
        */
        return [...quickSort(left),pivot,...quickSort(right)]
    };
  1. 快速排序成人版
function quickSort(arr, left, right) {
    /*
     * len为数组的长度;
     * left为需要数组中参与排序的起始点;right为数组中参与排序的终止点;
     * left如果有传数字那么就为left,没有传参则为0;
     * right如果有传参那么就为right,没有传参则为len-1;
     * 有传参可能会部分排序可能不会排序,没传参默认排序整个数组;
     * partitionIndex为分组界限;
     */
    var len = arr.length,
        partitionIndex,
        left = typeof left !== 'number' ? 0 : left,
        right = typeof right !== 'number' ? len - 1 : right;

    // 如果需要排序的起始索引小于终止索引则执行排序;递归的终止条件;
    if (left < right) {

        // partition的返回值作为partitionIndex来分隔数组;
        // 索引partitionIndex左边的元素均小于arr[partitionIndex];
        // 右边的元素均大于arr[partitionIndex];
        partitionIndex = partition(arr, left, right);

// 数组中小于arr[partitionIndex]的部分(索引left到partitionIndex-1)再次使用quickSort排序;
        quickSort(arr, left, partitionIndex - 1);

// 数组中大于arr[partitionIndex]的部分(索引partitionIndex+1到right)再次使用quickSort排序;
        quickSort(arr, partitionIndex + 1, right);
    }
    // 递归执行直到不满足left<right;返回本身;
    return arr;
}

function partition(arr, left, right) {
    /*
     * 这部分是具体实现排序的部分;
     * 将left赋值给pivot,作为参照物,因为left在最左边,只需要从左到右比较一遍即可判断整个数组;
     * index索引是arr中待交换位置;
     */
    var pivot = left,
        index = pivot + 1;
    // for循环从参照物arr[pivot]下一个元素arr[pivot+1]开始一直比较到子数组结束arr[right];
    for (var i = index; i <= right; i++) {

  // 循环中如果有任何小于参照物的,就将他交换到index的位置,然后index向右移动到下一个位置;
        if (arr[i] < arr[pivot]) {
            swap(arr, i, index);
            index++;
        }
    }
    /*
     * 因为每次都是交换完后index移动到下一个位置,所以在循环结束时,index仍为待交换的位置;
     * 此时索引pivot+1到index-1的元素都小于参照物arr[pivot];
     */

    // 交换pivot和index-1索引的值之后index-1索引左边全都是小于arr[index-1]的元素;
    swap(arr, pivot, index - 1);

    // 返回index-1作为拆分子数组的分界线;
    return index - 1;
}
/*
 * 普通的交换,将a[i]和a[j]的数值交换;
 */
function swap(arr, i, j) {
    var temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}

相关文章

  • JS实现排序算法

    原文:常见排序算法之JavaScript实现 - 知乎 目录 冒泡排序 选择排序 插入排序 合并排序 快速排序 1...

  • JavaScript实现快速排序算法的最佳实践,没有之一

    1.快速排序的基本思想 长话短说,排序算法中快速排序的性能还是不错的,今天我就讲讲javascript中实现快速排...

  • JavaScript实现经典排序算法

    使用JavaScript实现的经典排序算法 util 冒泡 简单选择 直接插入 快速排序 堆排序 归并排序

  • 快速排序(JavaScript)

    快速排序优化 1. 优化选取枢轴 三数取中法:即取三个关键字先进行排序,一般是取左端、右端和中间三个数,将中间数作...

  • JavaScript快速排序

    "快速排序"的思想很简单,整个排序过程只需要三步: (1)在数据集之中,选择一个元素作为"基准"(pivot)。 ...

  • Javascript快速排序

    快速排序大众版 快速排序成人版

  • JavaScript快速排序

    快速排序(Quicksort)算法使用广泛,速度也较快。它是图灵奖得主C. A. R. Hoare(1934--)...

  • JavaScript 快速排序

    选择排序是一种简单直观的排序算法,无论什么数据进去都是 O(n²) 的时间复杂度所以用到它的时候,数据规模越小越好...

  • javascript 快速排序算法

    今天给大家介绍的是javascript中的快速排序算法。 快速排序: 1、通过数组长度,来找到数组中间的那个值(基...

  • 快速排序的JS实现

    From:阮一峰 快速排序(Quicksort)的Javascript实现[https://www.ruanyif...

网友评论

      本文标题:Javascript快速排序

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