算法思想都是大致分为三步
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)); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!