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);
复制代码

 

posted @   大脸菌  阅读(2274)  评论(0编辑  收藏  举报
编辑推荐:
· .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 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示