当前位置: 首页 > news >正文

【算法】数组中,求K个最大值

 已知:数组 [8, 9, 15, 20, 3, 5, 7, 2, 6],求第8个最大值是哪个值?

function quickSort(arr, targetIndex, start) {if (arr.length <= 1) return arr[0];let left = [];let right = [];const mid = Math.floor(arr.length / 2);const midNum = arr.splice(mid, 1)[0];for (let i = 0; i < arr.length; i++) {if (arr[i] > midNum) {right.push(arr[i]);} else {left.push(arr[i]);}}if (left.length + start === targetIndex) {return midNum;} else if (left.length + start > targetIndex) {return quickSort(left, targetIndex, start);} else {return quickSort(right, targetIndex, left.length + start + 1);}
}
const findKthLargest = function (nums, k) {const num = quickSort(nums, nums.length - k, 0);return num;
};
console.log(findKthLargest([8, 9, 15, 20, 3, 5, 7, 2, 6], 8));

思路:

  • 取数组的中间索引元素midNum,循环数组,将小于midNum的元素放到left数组中,大于midNum的元素放到right数组中;
  • 比较小于midNum的left 数组的长度 + 之前的递归的左边的数组的长度 与 targetIndex的大小:
  • 如果大于targetIndex,继续递归循环left数组;
  • 如果小于targetIndex,递归循环right数组;
  • 如果等于targetIndex,返回当前中间索引midNum;
http://www.lryc.cn/news/498718.html

相关文章:

  • Postman自定义脚本Pre-request-script以及Test
  • Lua中实现HTTP请求的User-Agent自定义
  • 工业节能水泵如何节能?
  • 第四篇:k8s 理解Service工作原理
  • P3131 [USACO16JAN] Subsequences Summing to Sevens S
  • 大数据技术Kafka详解 ② | Kafka基础与架构介绍
  • 【CKA】Kubernetes(k8s)认证之CKA考题讲解
  • android WebRtc 无法推流以及拉流有视频无声音问题
  • 【5G】Spectrum 频谱
  • Flink学习连载文章11--双流Join
  • R语言 | 峰峦图 / 山脊图
  • 16-03、JVM系列之:内存与垃圾回收篇(三)
  • 解决Windows与Ubuntu云服务器无法通过Socket(udp)通信问题
  • Mysql 中的锁机制
  • 12月第1周AI资讯
  • 【音频识别】数据集合集!
  • Nginx核心配置详解
  • 智能工厂的设计软件 用“力force”的性质构造智能体原型
  • Apache AGE:基于PostgreSQL的图数据库
  • RabbitMQ延迟消息的实现
  • SAP在中国:助力企业跨越成长的新篇章
  • 数据结构代码归纳
  • 数仓技术hive与oracle对比(一)
  • 筑起厂区安全--叉车安全防护装置全解析
  • 深入浅出云计算 ---笔记
  • ARINC 标准全解析:航空电子领域多系列标准的核心内容、应用与重要意义
  • SNMP 协议介绍
  • Python中的数据结构深入解析:从列表到字典的优化技巧
  • 如何利用Java爬虫获得商品类目
  • 力扣面试题 32 - 检查平衡性 C语言解法