堆--数组中第K大元素
如果对于堆不是太认识,请点击:堆的初步认识-CSDN博客

解题思路:
/*** <h3>求数组中第 K 大的元素</h3>* <p>* 解体思路* <ol>* 1.向小顶堆放入前k个元素* 2.剩余元素* 若 <= 堆顶元素, 则略过* 若 > 堆顶元素, 则替换堆顶元素* 3.这样小顶堆始终保留的是到目前为止,前K大的元素* 4.循环结束, 堆顶元素即为第K大元素* </ol>*/
小顶堆(可删去用不到代码)
class MinHeap {int[] array;int size;public MinHeap(int capacity) {array = new int[capacity];}private void heapify() {for (int i = (size >> 1) - 1; i >= 0; i--) {down(i);}}public int poll() {swap(0, size - 1);size--;down(0);return array[size];}public int poll(int index) {swap(index, size - 1);size--;down(index);return array[size];}public int peek() {return array[0];}public boolean offer(int offered) {if (size == array.length) {return false;}up(offered);size++;return true;}public void replace(int replaced) {array[0] = replaced;down(0);}private void up(int offered) {int child = size;while (child > 0) {int parent = (child - 1) >> 1;if (offered < array[parent]) {array[child] = array[parent];} else {break;}child = parent;}array[child] = offered;}private void down(int parent) {int left = (parent << 1) + 1;int right = left + 1;int min = parent;if (left < size && array[left] < array[min]) {min = left;}if (right < size && array[right] < array[min]) {min = right;}if (min != parent) {swap(min, parent);down(min);}}// 交换两个索引处的元素private void swap(int i, int j) {int t = array[i];array[i] = array[j];array[j] = t;}
}
题解
public int findKthLargest(int[] numbers, int k) {MinHeap heap = new MinHeap(k);for (int i = 0; i < k; i++) {heap.offer(numbers[i]);}for (int i = k; i < numbers.length; i++) {if(numbers[i] > heap.peek()){heap.replace(numbers[i]);}}return heap.peek();
}
注意哦:求数组中的第 K 大元素,使用堆并不是最佳选择,可以采用快速选择算法
相关文章:
堆--数组中第K大元素
如果对于堆不是太认识,请点击:堆的初步认识-CSDN博客 解题思路: /*** <h3>求数组中第 K 大的元素</h3>* <p>* 解体思路* <ol>* 1.向小顶堆放入前k个元素* 2.剩余元素* 若 < 堆顶元素, 则略过* …...
ipad使用技巧
1、goodnotes中批量导入pdf文件 法一: 直接参考视频: 【目前为止所知iPad上goodnotes批量导入网盘文件最快的方法】 大致步骤:pdf文件传到百度网盘,然后ES软件登录百度网盘,在goodnotes中导入,选择ES&a…...
Windows系统上使用CLion远程开发Linux程序
CLion远程开发Linux程序 情景说明Ubuntu配置CLion配置同步 情景说明 在Windows系统上使用CLion开发Linux程序,安装CLion集成化开发环境时会自动安装cmake、mingw,代码提示功能也比较友好。 但是在socket开发时,包含sys/socket.h头文件时&am…...
github搜索技巧
指定语言 language:java 比如我要找用java写的含有blog的内容 搜索项目名称包含关键词的内容 vue in:name 其他如项目描述跟项目文档,如下 组合使用 vue in:name,description,readme 根据Star 或者fork的数量来查找 总结 springboot vue stars:>1000 p…...
Python生成器
生成器 Generators 要理解生成器,首先要理解迭代器,迭代器由以下三个部分组成: 可迭代对象(iterable)迭代器(iterator)迭代(iteration) 1. 可迭代对象 只要定义了可以…...
flutter开发实战-使用FutureBuilder异步数据更新Widget
flutter开发实战-使用FutureBuilder异步数据更新Widget 在开发过程中,经常遇到需要依赖异步数据更新Widget的情况,如下载图片后显示Widget,获取到某个数据时候,显示在对应的UI界面上,都可以使用FutureBuilder异步数据…...
1.2 数据模型
思维导图: 前言: **1.2.1 什么是模型** - **定义**:模型是对现实世界中某个对象特征的模拟和抽象。例如,一张地图、建筑设计沙盘或精致的航模飞机都可以视为具体的模型。 - **具体模型与现实生活**:具体模型可以很容…...
【实用工具】谷歌浏览器插件开发指南
谷歌浏览器插件开发指南涉及以下几个方面: 1. 开发环境准备:首先需要安装Chrome浏览器和开发者工具。进入Chrome应用商店,搜索“Extensions Reloader”和“Manifest Viewer”两个插件进行安装,这两个插件可以方便开发和调试。 2…...
应用层协议——DNS、DHCP、HTTP、FTP
目录 1、DNS 协议 1-1)Hosts 文件 1-2)DNS 系统 1-3)域名的组成、分类和树状结构 1-4)DNS 域名服务器类型 1-5)DNS 查询方式 1-6)DNS 域名解析的一般步骤 1-7)对象类型与资源记录 2、D…...
XML文件读写
0、.pro文件添加依赖 QT xml1、使用 QDomDocument 方式 #include <QtXml/QDomDocument> #include <QtXml/QDomProcessingInstruction> #include <QtXml/QDomElement> #include <QFile> #include <QTextStream> #include <QDebug>bo…...
Win11 安装 Vim
安装包: 链接:https://pan.baidu.com/s/1Ru7HhTSotz9mteHug-Yhpw?pwd6666 提取码:6666 双击安装包,一直下一步。 配置环境变量: 先配置系统变量中的path: 接着配置用户变量: 在 cmd 中输入…...
Mac电脑BIM建模软件 Archicad 26 for Mac最新
ARCHICAD 软件特色 智能化 在2D CAD中,所有的建筑构件都由线条构成和表现,仅仅是一些线条的组合而已,当我们阅读图纸的时候是按照制图规范来读取这些信息。我们用一组线条表示平面中的窗,再用另一组不同的线条在立面中表示同一个…...
JavaEE-网络编程套接字(UDP/TCP)
下面写一个简单的UDP客户端服务器流程 思路: 对于服务器端:读取请求,并解析–> 根据解析出的请求,做出响应(这里是一个回显,)–>把响应写回客户端 对于客户端:从控制台读取用户输入的内容–>从控制…...
微服务技术栈-Gateway服务网关
文章目录 前言一、为什么需要网关二、Spring Cloud Gateway三、断言工厂和过滤器1.断言工厂2.过滤器3.全局过滤器4.过滤器执行顺序 四、跨域问题总结 前言 在之前的文章中我们已经介绍了微服务技术中eureka、nacos、ribbon、Feign这几个组件,接下来将介绍另外一个组…...
函数形状有几种定义方式;操作符infer的作用
在 TypeScript 中,函数形状可以用多种方式进行定义。下面介绍了几种常用的函数形状定义方式: 函数声明: function add(a: number, b: number): number {return a b; }在函数声明中,我们直接使用 function 关键字来声明函数&…...
Java / MybatisPlus:JSON处理器的应用,在实体对象中设置对象属性,对象嵌套对象
1、数据库设计 2、定义内部的实体类 /*** Author lgz* Description* Date 2023/9/30.*/ Data // 静态构造staticName,方便构造对象并赋予属性 AllArgsConstructor(staticName "of") NoArgsConstructor ApiModel(value "亲友", description …...
力扣 -- 1027. 最长等差数列
解题步骤: 参考代码: class Solution { public:int longestArithSeqLength(vector<int>& nums) {int nnums.size();int ret2;unordered_map<int,int> hash;//这里可以先把nums[0]存进哈希表中,方便后面i从1开始遍历hash[num…...
正则验证用户名和跨域postmessage
正则验证用户名 字母数字符号大小写8-14匹配用户名的 <!DOCTYPE html> <html> <head><meta charset"utf-8"><meta name"viewport" content"widthdevice-width, initial-scale1"><title>form</title> …...
jsbridge实战1:xcode swift 构建iOS app
[[toc]] 环境安装 macOs: 10.15.5 xcode: 11.6 demo:app 创建 hello world iOS app 创建工程步骤 选择:Create a new Xcode project选择:iOS-> single View App填写: project name: swift-app-helloidentifer: smile 包名language: s…...
零基础部署nginx mysql springboot
参考:写给开发人员看的Docker干货,零基础部署nginx mysql springboot 一、连接linux 阿里云 参考:部署到Linux 可能需要购买:购买链接 二、安装docker # 先切换到root用户下 sudo su# 更新apt-get,保证apt-get最新…...
Qwen3.5-27B开源多模态模型部署案例:中文Web对话+图片理解双接口落地
Qwen3.5-27B开源多模态模型部署案例:中文Web对话图片理解双接口落地 1. 引言:一个模型,两种能力 想象一下,你有一个智能助手,不仅能和你流畅地中文聊天,还能看懂你发过去的图片,告诉你图片里有…...
基于NLP-StructBERT构建智能内容审核系统:网络安全文本过滤实战
基于NLP-StructBERT构建智能内容审核系统:网络安全文本过滤实战 每天,互联网上都会产生海量的文本内容——论坛里的讨论、电商平台的评论、社交媒体的动态。对于平台运营者来说,如何从这信息的洪流中,快速、准确地识别出那些违规…...
Stable Yogi Leather-Dress-Collection前沿实践:LoRA融合+动态CFG Scale调节
Stable Yogi Leather-Dress-Collection前沿实践:LoRA融合动态CFG Scale调节 今天要跟大家分享一个特别有意思的项目——Stable Yogi Leather-Dress-Collection。简单来说,这是一个能让你在本地电脑上,轻松生成各种动漫风格皮衣穿搭图片的工具…...
保姆级SAM 3入门指南:上传图片输入英文,轻松实现物体识别分割
保姆级SAM 3入门指南:上传图片输入英文,轻松实现物体识别分割 你是不是经常遇到这样的场景?看到一张精美的图片,想单独提取出里面的某个物体,比如一只可爱的猫、一本书,或者一个特别的Logo。手动抠图&…...
SpringBoot分层概念澄清 DTO、BO、VO
spring boot项目中: DTO就是前端到控制层 BO就是数据库到服务层 VO就是服务层到前端这样理解是否正确?在Spring Boot项目中,关于DTO、BO和VO的划分确实存在一些常见约定,但你的理解中有些地方需要进一步澄清。下面是对这些概念在典型分层架构…...
TMC4671 电机驱动芯片实战调试:从零到稳定运行的避坑指南
1. 硬件上电与连接:别让第一步就“翻车” 拿到TMC4671开发板,第一件事肯定不是急着写代码。我见过太多新手,包括我自己早年也犯过这个错,兴冲冲地连上电脑就开始调软件,结果折腾半天电机纹丝不动,最后发现是…...
1. 天空星HC32F4A0开发板驱动1.28寸圆形LCD屏实战:从软件SPI到硬件SPI的完整移植指南
天空星HC32F4A0开发板驱动1.28寸圆形LCD屏实战:从软件SPI到硬件SPI的完整移植指南 最近用天空星的HC32F4A0开发板做项目,需要驱动一块1.28寸的圆形LCD屏,屏幕驱动芯片是GC9A01。网上找的例程大多是软件模拟SPI的,虽然能用…...
InsightFace buffalo_l在Face Analysis WebUI中的多维度人脸属性解析案例
InsightFace buffalo_l在Face Analysis WebUI中的多维度人脸属性解析案例 1. 引言:从一张照片到一份“人物档案” 你有没有想过,一张普通的照片背后,能挖掘出多少关于“人”的信息?年龄、性别、情绪、甚至头部的微小转动角度&am…...
企业网站获取视频JS代码调用和通用iframe代码调用
企业网站获取视频JS代码调用和通用iframe代码调用。管理平台,自带生成视频预览地址、调用代码和iframe通用代码,用户可根据自己的实际情况,在企业网站或其他平台中进行视频调用,最常见的应用是在企业官网页面中调用,均…...
2026美妆行业自动图文发布工具推荐指南
2026美妆行业自动图文发布工具推荐指南行业背景与推荐依据据《2025年美妆行业数字化营销白皮书》显示,美妆行业线上营销投入占比已达68%,其中小红书、抖音两大平台的内容营销贡献了超过70%的线上获客量。随着内容营销的深化,美妆品牌普遍面临…...
