js算法——快速排序与快速选择

简介: js算法——快速排序与快速选择

快速排序


创建用于交换数组两个值的函数swap

创建quick快速排序函数,入参i为起始下标,j为末尾下标

我们将起始下标i对应的arr[i]值作为基准,声明两个哨兵,l与r分别代表左侧哨兵和右侧哨兵,初始位于起始下标和末尾下标。

r向左侧移动,寻找到第一个小于(若降序则相反)基准的值;l向右侧移动,寻找到第一个大于(若降序则相反)基准的值,找到后交换,并继续找下一对值交换,寻找条件要确保左侧哨兵和右侧哨兵没有相遇:l<r。

当哨兵相遇时,将相遇点的值与基准值交换,得到的相遇点的值为基准中心,左侧的值一定小于它,右侧的一定大于它。

将相遇点左侧与右侧继续递归,递归条件为基准中心左侧l-1下标值大于起始下标i,也就是相遇点左侧至少存在两个数,右侧同理,递归完毕,值从小到大进行排序。

   //对应解释1
   const swap=(arr,a,b)=>{
       [arr[a],arr[b]]=[arr[b],arr[a]]
   }
   //对应解释2
   const quick=(arr,i,j)=>{
      //对应解释3
      let l=i,r=j
      //对应解释4
      while(l<r){
          while(l<r&&arr[r]>=arr[i]) r--
          while(l<r&&arr[l]<=arr[i]) l++
          swap(arr,l,r)
      }
      //对应解释5
      swap(arr,i,l)
      //对应解释6
      if(l-1>i){
        quick(arr,i,l-1)
      }
      if(l+1<j){
        quick(arr,l+1,j)
      }
   }
   quick(arr,0,arr.length-1)

快速选择


  1. 例如寻找前k个最小的数,快速排序时左侧值会小于基准中心,因此每次找到基准中心如果基准中心:
    若等于k则已经找到前k个最小值了,返回前k个即可;
    若大于k,则右侧数排除,继续排序左侧即可;
    若小于k,则左侧数已经在前k个最小值的范围内了,顺序无所谓,继续排序右
   const swap=(arr,a,b)=>{
       [arr[a],arr[b]]=[arr[b],arr[a]]
   }
   const quick=(arr,i,j)=>{
      let l=i,r=j
      while(l<r){
          while(l<r&&arr[r]>=arr[i]) r--
          while(l<r&&arr[l]<=arr[i]) l++
          swap(arr,l,r)
      }
      swap(arr,i,l)
      //对应解释
      if(l===k){
         return arr.slice(0,k)
      }else if(l>k){
         return quick(arr,i,l-1)
      }else {
         return quick(arr,l+1,j)
      }
   }
   const res= quick(arr,0,arr.length-1)

例如寻找第k个大的数,降序排序的话快速排序时左侧值会大于基准中心,因此每次找到基准中心如果基准中心:

若等于k-1则已经找到那个第k个(arr[k-1])大的数了,返回即可;

若大于k-1,则第k大的数必定在左侧,右侧数全排除,继续排序左侧即可;

若小于k-1,则左侧数(不超过k个)是都大于第k大的数,顺序无所谓直接排除,继续排序右侧。

   const swap=(arr,a,b)=>{
       [arr[a],arr[b]]=[arr[b],arr[a]]
   }
   const quick=(arr,i,j)=>{
      let l=i,r=j
      while(l<r){
          while(l<r&&arr[r]>=arr[i]) r--
          while(l<r&&arr[l]<=arr[i]) l++
          swap(arr,l,r)
      }
      swap(arr,i,l)
      //对应解释
      if(l===k-1){
         return arr[k-1]
      }else if(l>k-1){
         return quick(arr,i,l-1)
      }else {
         return quick(arr,l+1,j)
      }
   }
   const res= quick(arr,0,arr.length-1)
相关文章
|
2月前
|
存储 监控 算法
局域网监控其他电脑的设备信息管理 Node.js 跳表算法
跳表通过分层索引实现O(logn)的高效查询、插入与删除,适配局域网监控中设备动态接入、IP映射及范围筛选等需求,相比传统结构更高效稳定,适用于Node.js环境下的实时设备管理。
116 9
|
4月前
|
存储 监控 JavaScript
基于布隆过滤器的 Node.js 算法在局域网电脑桌面监控设备快速校验中的应用研究
本文探讨了布隆过滤器在局域网电脑桌面监控中的应用,分析其高效空间利用率、快速查询性能及动态扩容优势,并设计了基于MAC地址的校验模型,提供Node.js实现代码,适用于设备准入控制与重复数据过滤场景。
198 0
|
2月前
|
存储 监控 JavaScript
企业上网监控系统的恶意 URL 过滤 Node.js 布隆过滤器算法
布隆过滤器以低内存、高效率特性,解决企业上网监控系统对百万级恶意URL实时检测与动态更新的难题,通过概率性判断实现毫秒级过滤,内存占用降低96%,适配大规模场景需求。
232 3
|
2月前
|
存储 监控 算法
电脑管控软件的进程优先级调度:Node.js 红黑树算法
红黑树凭借O(log n)高效插入、删除与查询特性,适配电脑管控软件对进程优先级动态调度的高并发需求。其自平衡机制保障系统稳定,低内存占用满足轻量化部署,显著优于传统数组或链表方案,是实现关键进程资源优先分配的理想选择。
145 1
|
3月前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
236 3
|
7月前
|
监控 算法 JavaScript
基于 JavaScript 图算法的局域网网络访问控制模型构建及局域网禁止上网软件的技术实现路径研究
本文探讨局域网网络访问控制软件的技术框架,将其核心功能映射为图论模型,通过节点与边表示终端设备及访问关系。以JavaScript实现DFS算法,模拟访问权限判断,优化动态策略更新与多层级访问控制。结合流量监控数据,提升网络安全响应能力,为企业自主研发提供理论支持,推动智能化演进,助力数字化管理。
191 4
|
7月前
|
监控 算法 JavaScript
公司局域网管理视域下 Node.js 图算法的深度应用研究:拓扑结构建模与流量优化策略探析
本文探讨了图论算法在公司局域网管理中的应用,针对设备互联复杂、流量调度低效及安全监控困难等问题,提出基于图论的解决方案。通过节点与边建模局域网拓扑结构,利用DFS/BFS实现设备快速发现,Dijkstra算法优化流量路径,社区检测算法识别安全风险。结合WorkWin软件实例,展示了算法在设备管理、流量调度与安全监控中的价值,为智能化局域网管理提供了理论与实践指导。
186 3
|
7月前
|
存储 监控 算法
公司内部网络监控中的二叉搜索树算法:基于 Node.js 的实时设备状态管理
在数字化办公生态系统中,公司内部网络监控已成为企业信息安全管理体系的核心构成要素。随着局域网内终端设备数量呈指数级增长,实现设备状态的实时追踪与异常节点的快速定位,已成为亟待解决的关键技术难题。传统线性数据结构在处理动态更新的设备信息时,存在检索效率低下的固有缺陷;而树形数据结构因其天然的分层特性与高效的检索机制,逐渐成为网络监控领域的研究热点。本文以二叉搜索树(Binary Search Tree, BST)作为研究对象,系统探讨其在公司内部网络监控场景中的应用机制,并基于 Node.js 平台构建一套具备实时更新与快速查询功能的设备状态管理算法框架。
264 3
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
290 2
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
221 1
JavaScript中的原型 保姆级文章一文搞懂

热门文章

最新文章