数据结构学习 jz59 滑动窗口的最大值

2024-01-15 23:36

本文主要是介绍数据结构学习 jz59 滑动窗口的最大值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关键词:排序 大顶堆 双端队列

题目: 望远镜中最高的海拔

方法一:维护一个辅助队列。

方法二:大顶堆。

我还在主站 239 写了找最小值的方法。

方法一:最优解

这个方法和jz30维护一个非严格递减的辅助栈是基本一样的。

思路:

看了k神答案才懵懵懂懂会。建议看。

维护一个limit大小的双端队列作为辅助,这个双端队列存的是有可能成为最大值的潜在选手,如果在这个窗口内,后面的数大过了一些潜在选手,那么就把这些不够大的潜在选手淘汰(pop)。

我们需要一直保持这个双端的队列的非严格递减性。

可以将 “未形成窗口” 和 “形成窗口后” 两个阶段拆分到两个循环里实现。

复杂度计算:

时间复杂度O(n)

空间复杂度O(limit)

代码:

class Solution {
public:vector<int> maxAltitude(vector<int>& heights, int limit) {vector<int> result;if(heights.empty()||limit==0) return result;deque<int> dq;//双端非严格递减队列dq.push_back(heights[0]);//初始化第一个数//未形成窗口for(int i=1;i<limit;++i){while(!dq.empty()&&heights[i]>dq.back()) {dq.pop_back();}dq.push_back(heights[i]);}result.push_back(dq[0]);//形成窗口for(int i=limit;i<heights.size();++i){//出栈最大值if(heights[i-limit]==dq[0]){dq.pop_front();}while(!dq.empty()&&heights[i]>dq.back()){dq.pop_back();}dq.push_back(heights[i]);result.push_back(dq[0]);}return result;}
};

方法二:

 大顶堆,优先序列。记录pair(val,index),top的index如果超过了窗口左端,就推出。

思路:

这个方法很好理解,我刚开始也是希望用大顶堆做,但是没想到怎么删除已经超过窗口的数,这里给了我启发,只要记录一个pair(val,index),就可以了。

在查询最大值的时候,同时检查index,如果超过了窗口的左端,那么就直接pop,直到找到窗口内的最大值。

复杂度计算:

时间复杂度O(nlogn)

空间复杂度O(n)

代码:

class Solution {
public:vector<int> maxAltitude(vector<int>& heights, int limit) {vector<int> result;if(heights.empty()||limit==0) return result;priority_queue<pair<int,int>> q;//未形成窗口前for(int i=0;i<limit;++i){q.push({heights[i],i});}result.push_back(q.top().first);//形成窗口后for(int i=limit;i<heights.size();++i){q.push({heights[i],i});while(q.top().second<=i-limit){q.pop();}result.push_back(q.top().first);}return result;}
};

这篇关于数据结构学习 jz59 滑动窗口的最大值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/610564

相关文章

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx