美文网首页
js算法排序-快速排序

js算法排序-快速排序

作者: 小猪佩奇的王子 | 来源:发表于2019-10-30 11:53 被阅读0次
    /**
     * 快速排序
     * 在列表中间位置取值,作为基准数字,对剩余数据(已去除基准)进行和基准的比较,
     * 大于基准的放右边,小于基准的放左边
     * 然后对左右列表再次进行同样的操作,直到列表中只有一个元素
     * @param {*} arr
     */
    function quickSort(arr) {
        if (arr.length <= 1) {
            return arr
        }
        var pivotIndex = Math.floor(arr.length / 2)
        var pivot = arr.splice(pivotIndex, 1)[0]
    
        var left = [],
            right = []
    
        for (var i = 0; i < arr.length; i++) {
            if (arr[i] < pivot) {
                left.push(arr[i])
            } else {
                right.push(arr[i])
            }
        }
        return quickSort(left).concat([pivot], quickSort(right))
    }
    
    // console.log(quickSort(arr))
    

    相关文章

      网友评论

          本文标题:js算法排序-快速排序

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