JS实现快排
快速排序的概念
快速排序(维基百科) https://zh.wikipedia.org/wiki/%E5%BF%AB%E9%80%9F%E6%8E%92%E5%BA%8F
白话算法 - 快速排序 http://blog.csdn.net/morewindows/article/details/6684558
递归方法实现
1 function quickSort(arr, start, end) { 2 if (start > end) { 3 return; 4 } 5 let i = start, 6 j = end, 7 pivot = arr[start]; //存放基准数 8 while (i !== j) { 9 // 从右边开始,找第一个小于基准的位置 10 while (arr[j] >= pivot && i < j) { 11 j--; 12 } 13 // 从左边开始,找第一个大于基准的位置 14 while (arr[i] <= pivot && i < j) { 15 i++ 16 } 17 // 交换两个数 18 if (i < j) { 19 let tmp = arr[i]; 20 arr[i] = arr[j]; 21 arr[j] = tmp; 22 } 23 } 24 // 最后把基准数归位 25 arr[start] = arr[i]; 26 arr[i] = pivot; 27 // 递归处理左边 28 quickSort(arr, start, i - 1); 29 // 递归处理右边 30 quickSort(arr, i + 1, end); 31 } 32 var arr = [6, 1, 2, 7, 9, 3, 4, 5, 10, 8]; 33 quickSort(arr, 0, arr.length - 1); 34 console.log(arr);
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义