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

更弱智的算法学习 day48

单调栈基础

通常是一维数组,要寻找任一个元素的右边或者左边第一个比自己大或者小的元素的位置,此时我们就要想到可以用单调栈了,时间复杂度为O(n)。

739. 每日温度

构建一个栈,用来一次存储从大到小的元素(栈底大,栈顶小),从后向前遍历每日温度,和栈订的数据进行比较,可能出现如下的情况:

1:栈内要有元素!!!!

2:第i日温度大于栈顶的温度:

此时栈顶的温度并非最高,由于是从后向前遍历,也即存在栈顶元素之前的某一天,温度高于栈顶,如下图的5和2,也即2不会对前面的时间产生影响(不会成为前面日子升高气温的某一天,因为5代替了他的效果)。因此,pop()掉没有第i日高的温度。

3:等于:同上理

4:第i日温度小于栈顶的温度:

也即此时可能有贡献,加入到栈中

在执行完弹出操作后,如果栈非空,那么栈顶元素就是距离第i天右边最近的、温度比它高的日子的索引。因此,等待的天数就是stack[-1] - i,并将其存入ans[i]。如果栈为空,则说明右边没有更高的温度,ans[i]保持为0

class Solution: def dailyTemperatures(self, temperatures: List[int]) -> List[int]: n = len(temperatures) stack = [] ans = [0]*n for i in range(n-1 ,-1 ,-1): t = temperatures[i] while stack and t >= temperatures[stack[-1]]: stack.pop() if stack: ans[i] = stack[-1] - i stack.append(i) return ans

496.下一个更大元素 I

下面是暴力搜索的方法,侥幸没超时

class Solution: def nextGreaterElement(self, nums1: List[int], nums2: List[int]) -> List[int]: m = len(nums1) n = len(nums2) ans = [-1] * m stack = [] for i in range(m): for j in range(n-1, -1, -1): if nums2[j] > nums1[i]: stack.append(nums2[j]) elif nums2[j] == nums1[i] and stack: ans[i] = stack[-1] print(stack) stack = [] return ans

单调栈方法

考虑建立nums1和nums2之间的映射,然后在nums2中进行单调栈处理即可。

在栈非空且遍历到的元素大于栈顶元素时,也即找到了该栈顶元素的最近的较大数,不断查找栈顶元素在nums1中是否存在,存在的话就存储到结果中。

处理完之后加入栈中

class Solution: def nextGreaterElement(self, nums1: List[int], nums2: List[int]) -> List[int]: m = len(nums1) n = len(nums2) idx = {x:i for i,x in enumerate(nums1)} ans = [-1] * m stack = [] for p in range(n): while stack and nums2[p] > nums2[stack[-1]]: k = stack.pop() if nums2[k] in idx: ans[idx[nums2[k]]] = nums2[p] stack.append(p) return ans

503.下一个更大元素II

和上面一题思路非常类似,由于存在循环,可以将数组扩展复制一份继续检查,也即实现了循环的效果

class Solution: def nextGreaterElements(self, nums: List[int]) -> List[int]: n = len(nums) ans = [-1]*n stack = [] for i in range(n): nums.append(nums[i]) for j in range(2*n): while stack and nums[j] > nums[stack[-1]]: k = stack.pop() if k < n: ans[k] = nums[j] stack.append(j) return ans
http://www.jsqmd.com/news/268655/

相关文章:

  • Flux.1-dev创意变现:非商用的合法途径
  • 【dz-1011】酒窖存储环境监测与控制系统设计
  • 学生党福利:NewBie-image-Exp0.1云端体验,比买显卡省90%
  • 数字员工提升AI销冠系统与AI提效软件系统的生产力和运营效益
  • ue5 默认相机设置
  • 为什么高并发普遍用Java不用C++,C#,Rust或go?
  • Qwen3-VL多模态开发:免GPU调试技巧
  • C++ 的核心究竟是什么?学到什么程度才算精通?
  • 没CUDA也能玩Live Avatar?云端方案解救配置恐惧症
  • springcloud技术体系里有gateway网关,那还需要nginx吗?
  • DeepSeek-R1-Distill-Qwen-1.5B企业内网方案:云端专属GPU集群
  • 数据库性能优化:SQL 语句的优化(原理+解析+面试)
  • C++ dll 设计接口时,能否用shared_ptr作为接口返回值?
  • gpt-oss-20b-WEBUI文本生成实战:云端3步快速体验
  • VibeThinker-1.5B降本秘诀:夜间3毛/小时,错峰实验省千元
  • Llama3-8B问答系统搭建:云端GPU3步搞定,1小时1块钱
  • Wan2.2开箱即用镜像:0配置部署,1块钱起体验最新模型
  • Qwen-Image-Edit-2511智能修图入门:5分钟云端体验,零技术门槛
  • 2026最新指南:作业帮下载安装全流程详解与实用技巧
  • BGE-Reranker-v2-m3快速原型开发:云端IDE+GPU,效率翻倍
  • 【2026 最新】飞火动态壁纸下载安装教程|从下载到配置的完整流程解析
  • DeepSeek-R1长期运行方案:云端GPU+自动启停,省心省钱
  • 当遇到MFCD42D.DLL文件丢失找不到问题 免费下载方法分享
  • AI视频医疗应用:快速搭建医学影像分析与教育视频平台
  • Supertonic商业应用评估:按需付费测试,省下80%成本
  • 《Advanced Optical Materials》最新研究:布洛赫点作为“光学拓扑处理器”的理论与仿真突破
  • 新手必看!Lora训练开箱即用方案,没显卡也能当炼丹师
  • 证件照尺寸自动适配:AI云端工具支持全球50+标准
  • AI动画制作革命:MediaPipe Holistic让个人工作室省10万
  • 【无人机路径规划】基于RRT和LQR线性控制器和非线性 PD 控制器实现无人机在非线性动力学模型下精准跟踪规划路径附matlab代码