随笔- 18  文章- 1  评论- 2  阅读- 3652 

算法思想都是大致分为三步

1、找基准pivot

2、遍历数组,小于基准的放在left,大于基准的放在right

3、递归

js实现

复制代码
function quick(arr){
    if(arr.length<=1){
        return arr;
    }//如果数组<=1,则直接返回
    var pivotIndex=Math.floor(arr.length/2);
    //找基准,并把基准从原数组中删除
    var povet=arr.spilce(pivotIndex,1)[0];
    //定义左右数组
    var left = [];
    var right = [];
    
    //比基准小的放在left,比基准大的放在right
        for(var i = 0;i<arr.length;i++){
            if(arr[i]>k){
                right.push(arr[i]);
            }else{
                left.push(arr[i]);
            }
        }
        //递归
        return quick(left).concat([k],quick(right));
}
复制代码

 

 posted on   Dopazt  阅读(220)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示