js原地快排

本文深入探讨JavaScript中的原地快速排序算法,这是一种高效且不占用额外空间的排序方法,通过选择枢轴元素并重新排列数组来实现。了解其工作原理及实现细节。

原地快拍

/*
 * @author: linzl
 * @method: 
 * @param: 
 * @Date: 2021-04-25 21:40:46
 * @return: 
 */
function qsort(arr, start, end){ 
    if(start >= end) return 
    let i = start, j = end
    let mid = arr[start]
    while(i<j){
        while(i<j && arr[j] >= mid){
            j--
        }
        if(i<j){
            arr[i] = arr[j]
        }

        while(i<j && arr[i] <= mid){
            i++
        }
        if(i<j){
            arr[j] = arr[i]
        }
    } 
    arr[i] = mid
    qsort(arr, start, i-1)
    qsort(arr, i+1, end)
}
let array =[4,8,9,7,5,3,5,4,5,8,1,6]
qsort(array, 0, array.length-1)
console.log(array);
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值