news 2026/4/23 6:48:37

go栈与队列之窗口最大值

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
go栈与队列之窗口最大值

力扣题目链接:

239. 滑动窗口最大值 - 力扣(LeetCode)

题目描述:

给你一个整数数组nums,有一个大小为k的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的k个数字。滑动窗口每次只向右移动一位。

返回滑动窗口中的最大值

示例 1:

输入:nums = [1,3,-1,-3,5,3,6,7], k = 3输出:[3,3,5,5,6,7]解释:滑动窗口的位置 最大值 --------------- ----- [1 3 -1] -3 5 3 6 731 [3 -1 -3] 5 3 6 731 3 [-1 -3 5] 3 6 751 3 -1 [-3 5 3] 6 751 3 -1 -3 [5 3 6] 761 3 -1 -3 5 [3 6 7]7

这道题很适合用单调队列来写,这样外面很容易通过一侧的值就知道最大值了。什么是单调队列?其实就是单调递增或单调递减队列。那么就用单调递减队列来设计吧。

单调递减队列是左边(队列出口处)的值最大,所以窗口最大值就是索引0处,通过队列的pop()和push()函数,来设计吧。

最开始的滑动窗口值,只能用push()函数,通过它让我们的队列成单调递减,那么我们先设计push()函数。

例:单减数列: 出口处 9 8 7 4 入口处

当要进来的元素比入口处元素大时,进来后就不成单减队列了,所以要先比较,把比他大的元素都弹出,然后再将该元素加入队列

再设计pop()函数,由刚才的push()函数设计就知道,队列里面的元素个数不一定等于滑动窗口里的元素个数。所以队列的元素个数一定小于等于滑动窗口元素个数。那么我们就不用每次pop()都一定弹出元素。所以我们要弹出的元素等于出口处元素时才需要弹出元素。

现在就设计完成了单调队列,之后就很容易了

完整代码:

func MaxSlidingWindow(nums []int, k int) []int { myque := make(queue, 0) result := make([]int, 0) //初始窗口 for i := 0; i < k; i++ { myque.push(nums[i]) } //初始窗口值 result = append(result, myque.front()) for i := k; i < len(nums); i++ { myque.pop(nums[i-k]) //移除前面的元素 myque.push(nums[i]) //添加新的元素 result = append(result, myque.front()) } return result } // 单调队列(由大到小) type queue []int // 比入口元素大的就弹出元素,直到比它小 func (s *queue) push(x int) { for len(*s) > 0 && x > (*s)[len(*s)-1] { *s = (*s)[:len(*s)-1] //弹出入口元素 } *s = append(*s, x) } // 若移除的元素等于出口元素就弹出 func (s *queue) pop(x int) { if len(*s) > 0 && x == (*s)[0] { *s = (*s)[1:] } } // 返回窗口最大值 func (s *queue) front() int { return (*s)[0] }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 22:31:08

Joy-Con Toolkit全攻略:解决手柄问题的终极工具

Joy-Con Toolkit全攻略&#xff1a;解决手柄问题的终极工具 【免费下载链接】jc_toolkit Joy-Con Toolkit 项目地址: https://gitcode.com/gh_mirrors/jc/jc_toolkit 还在为Joy-Con手柄的漂移、连接不稳定和个性化配置不足而烦恼吗&#xff1f;Joy-Con Toolkit作为一款专…

作者头像 李华
网站建设 2026/4/18 9:53:03

如何用FunClip实现智能高效的视频剪辑:零基础安装指南

如何用FunClip实现智能高效的视频剪辑&#xff1a;零基础安装指南 【免费下载链接】FunClip Open-source, accurate and easy-to-use video clipping tool, LLM based AI clipping intergrated || 开源、精准、方便的视频切片工具&#xff0c;集成了大语言模型AI智能剪辑功能 …

作者头像 李华
网站建设 2026/4/18 1:24:39

Hanime1观影助手:Android平台视频体验增强完全指南

Hanime1观影助手&#xff1a;Android平台视频体验增强完全指南 【免费下载链接】Hanime1Plugin Android插件(https://hanime1.me) (NSFW) 项目地址: https://gitcode.com/gh_mirrors/ha/Hanime1Plugin 一、问题发现&#xff1a;移动观影的现代困境 1.1 用户旅程中的痛点…

作者头像 李华
网站建设 2026/4/18 5:45:14

开机自动切换目录+执行程序,一气呵成

开机自动切换目录执行程序&#xff0c;一气呵成 你有没有遇到过这样的场景&#xff1a;每天开机后都要重复做几件事——先切到项目目录&#xff0c;再启动某个服务或仿真程序&#xff0c;最后还要确认它跑起来了&#xff1f;手动操作不仅费时&#xff0c;还容易出错。更糟的是…

作者头像 李华
网站建设 2026/3/30 18:39:47

MacOS环境配置与开源工具部署:ComfyUI-Manager实战指南

MacOS环境配置与开源工具部署&#xff1a;ComfyUI-Manager实战指南 【免费下载链接】ComfyUI-Manager 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Manager 在MacOS环境下进行开源工具部署时&#xff0c;开发者常面临依赖冲突、权限限制和性能优化等挑战。本…

作者头像 李华
网站建设 2026/4/19 2:33:29

如何用开源串流工具打造家庭游戏娱乐中心

如何用开源串流工具打造家庭游戏娱乐中心 【免费下载链接】moonlight-tv Lightweight NVIDIA GameStream Client, for LG webOS for Raspberry Pi 项目地址: https://gitcode.com/gh_mirrors/mo/moonlight-tv 想在客厅大屏幕上畅玩3A大作&#xff0c;又不想花费数千元购…

作者头像 李华