news 2026/4/18 13:12:33

更弱智的算法学习 day48

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
更弱智的算法学习 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
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:34:56

拒稿率暴跌 90%!虎贲等考 AI:期刊论文从选题到见刊的智能加速器

据《自然》期刊统计&#xff0c;全球 78% 的学术论文因写作问题被拒稿&#xff0c;其中结构性缺陷和学术规范失误占比超 80%。对科研人来说&#xff0c;一篇期刊论文从构思到见刊&#xff0c;往往要经历选题碰壁、文献堆砌、格式错乱、查重超标等多重考验。而虎贲等考 AI 智能写…

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

没CUDA也能玩Live Avatar?云端方案解救配置恐惧症

没CUDA也能玩Live Avatar&#xff1f;云端方案解救配置恐惧症 你是不是也曾经因为想用AI工具&#xff0c;却被“安装CUDA驱动”“配置cuDNN”“PyTorch版本不匹配”这些术语劝退过&#xff1f;尤其是像Live Avatar这种实时数字人直播技术&#xff0c;听起来酷炫&#xff0c;但…

作者头像 李华
网站建设 2026/4/18 3:31:51

什么是 Unix Socket?

Unix Socket&#xff08;通常称为 Unix Domain Socket&#xff0c;UDS&#xff09;是一种 仅在同一台主机内部使用的进程间通信&#xff08;IPC, Inter-Process Communication&#xff09;机制。它利用文件系统路径作为通信端点&#xff0c;通过内核在本机进程之间高效地传递数…

作者头像 李华
网站建设 2026/4/18 3:33:58

【干货收藏】2025年中国大模型案例100精选:程序员学习必备

本文汇总了2025年中国最具代表性的100个大模型应用案例&#xff0c;涵盖金融、零售、能源、医疗、制造等多领域。数据显示&#xff0c;大模型在智能客服、知识助手等场景应用广泛&#xff0c;价值性和创新性显著提升。文中精选了广发证券、国家电网、小米等企业的实践案例&…

作者头像 李华
网站建设 2026/4/18 3:35:28

Python 学习笔记:编程环境配置

[!NOTE] 笔记说明 根据之前在《[[关于Python的学习]]》一文中的规划&#xff0c;这篇笔记中将会具体记录配置 Python 编程环境所需执行的操作步骤&#xff0c;这些操作将着重于解决以下问题&#xff1a; 如何根据具体需求来配置运行时环境&#xff1b;如何基于具体的项目来搭建…

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

XGBoost特征重要性动态分析实战

&#x1f493; 博客主页&#xff1a;借口的CSDN主页 ⏩ 文章专栏&#xff1a;《热点资讯》 XGBoost特征重要性动态分析实战&#xff1a;从静态洞察到实时决策的范式跃迁目录XGBoost特征重要性动态分析实战&#xff1a;从静态洞察到实时决策的范式跃迁 引言&#xff1a;为何静态…

作者头像 李华