更弱智的算法学习 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.mzph.cn/news/1184248.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flux.1-dev创意变现:非商用的合法途径

Flux.1-dev创意变现&#xff1a;非商用的合法途径 你是不是也听说过 Flux.1-dev 这个强大的文生图AI模型&#xff1f;它生成的图像质量极高&#xff0c;细节丰富&#xff0c;人物面部、毛发、衣物纹理都清晰逼真&#xff0c;甚至能精准还原复杂提示词。更吸引人的是——它是开…

【dz-1011】酒窖存储环境监测与控制系统设计

摘要 在酒类存储领域&#xff0c;酒窖环境参数的稳定对酒品品质与存储安全起着决定性作用。传统酒窖环境管理多依赖人工检查和经验调控&#xff0c;存在数据记录不及时、环境波动难把控、异常响应滞后等问题&#xff0c;难以满足高品质酒类存储的严苛需求。 基于 STM32F103C8…

学生党福利:NewBie-image-Exp0.1云端体验,比买显卡省90%

学生党福利&#xff1a;NewBie-image-Exp0.1云端体验&#xff0c;比买显卡省90% 你是不是也和我一样&#xff0c;是计算机专业的学生&#xff0c;正想做一个AI绘画相关的课题&#xff0c;却被现实狠狠“教育”了一顿&#xff1f;实验室的GPU要排队申请&#xff0c;等轮到你可能…

数字员工提升AI销冠系统与AI提效软件系统的生产力和运营效益

数字员工在企业的运营中发挥了重要作用&#xff0c;通过优化业务流程、降低人工成本和提升工作效率&#xff0c;为AI销冠系统带来了显著的价值。借助自动化外呼功能&#xff0c;数字员工能够高效处理客户联系&#xff0c;大幅提高沟通频率&#xff0c;促使企业快速响应市场需求…

ue5 默认相机设置

目录 设置默认视口PlayerStart Pilot&#xff08;Pilot Camera&#xff09; 关卡蓝图添加相机 place actor 把 相机Actor 放到当前关卡中 设置默认视口PlayerStart ue5.5 加载新关卡&#xff0c;里面不是PlayerStart&#xff0c;切换默认PlayerStart的方法&#xff1a; pla…

为什么高并发普遍用Java不用C++,C#,Rust或go?

2025~2026年的现实情况是&#xff1a;互联网真正“超大规模、高并发、长生命周期、赚钱养家”的核心业务系统&#xff0c;仍然以 Java 占绝对统治地位&#xff08;尤其是中国互联网大厂和全球很多中大型公司&#xff09;&#xff0c;而 Go、Rust、C、C# 虽然在某些细分场景非常…

Qwen3-VL多模态开发:免GPU调试技巧

Qwen3-VL多模态开发&#xff1a;免GPU调试技巧 你是不是也遇到过这样的情况&#xff1f;作为App开发团队的一员&#xff0c;你们想给应用加上“看图说话”这种酷炫的图片理解功能&#xff0c;比如让用户上传一张照片&#xff0c;系统就能自动识别内容并生成描述。听起来很AI&a…

C++ 的核心究竟是什么?学到什么程度才算精通?

C 的核心究竟是什么&#xff1f; 一句话浓缩&#xff08;2025-2026 社区最常见的几种主流共识版本&#xff0c;按出现频率排序&#xff09;&#xff1a; 最被广泛接受的版本&#xff08;Bjarne Stroustrup 本人 C Core Guidelines 精神&#xff09;&#xff1a; “零开销抽象 …

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

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

springcloud技术体系里有gateway网关,那还需要nginx吗?

在 Spring Cloud 技术体系中有了 Spring Cloud Gateway&#xff08;以下简称 Gateway&#xff09;之后&#xff0c;是否还需要 Nginx&#xff1f;答案是&#xff1a;大多数生产级项目中仍然需要&#xff0c;但不是必须&#xff0c;取决于你的具体场景、并发规模、安全要求和运维…

DeepSeek-R1-Distill-Qwen-1.5B企业内网方案:云端专属GPU集群

DeepSeek-R1-Distill-Qwen-1.5B企业内网方案&#xff1a;云端专属GPU集群 在金融行业&#xff0c;AI模型的落地应用正变得越来越普遍——从智能客服、风险评估到自动化报告生成。但一个核心难题始终存在&#xff1a;数据安全不能妥协&#xff0c;敏感客户信息绝不能出内网。与…

数据库性能优化:SQL 语句的优化(原理+解析+面试)

数据库性能优化&#xff1a;SQL 语句的优化&#xff08;原理解析面试&#xff09; 一、基础查询 SQL 优化&#xff08;最常用&#xff09; 这类优化主要针对单表查询&#xff0c;核心是减少数据扫描范围、避免索引失效。 1. 杜绝「全字段查询」和「冗余字段」 问题&#xff1a;…

C++ dll 设计接口时,能否用shared_ptr作为接口返回值?

C DLL 设计接口时&#xff0c;能否用 shared_ptr 作为接口返回值&#xff1f; 最简短的行业共识答案&#xff08;2025-2026&#xff09;&#xff1a; 强烈不推荐&#xff0c;绝大多数生产级项目都不这么做&#xff0c;几乎所有成熟的 C DLL 接口规范都明确禁止这样做。 为什…

gpt-oss-20b-WEBUI文本生成实战:云端3步快速体验

gpt-oss-20b-WEBUI文本生成实战&#xff1a;云端3步快速体验 你是不是也经常刷到同行用AI写出爆款文章&#xff0c;标题吸睛、内容流畅、观点犀利&#xff0c;仿佛背后有个专业编辑团队&#xff1f;而你自己还在熬夜改稿、绞尽脑汁想选题&#xff0c;效率低还不出效果。更头疼…

VibeThinker-1.5B降本秘诀:夜间3毛/小时,错峰实验省千元

VibeThinker-1.5B降本秘诀&#xff1a;夜间3毛/小时&#xff0c;错峰实验省千元 你是不是也经历过这样的时刻&#xff1f;手头有个AI项目要跑批量推理任务&#xff0c;比如自动解数学题、生成算法逻辑链、做形式化验证&#xff0c;结果一算成本——GPU云服务每小时几块钱&…

Llama3-8B问答系统搭建:云端GPU3步搞定,1小时1块钱

Llama3-8B问答系统搭建&#xff1a;云端GPU3步搞定&#xff0c;1小时1块钱 你是不是也和我一样&#xff0c;研究生阶段突然被导师安排做一个智能问答系统课题&#xff0c;结果发现实验室没GPU、自己电脑跑不动大模型&#xff0c;一加载Llama3就卡死&#xff1f;别慌&#xff0…

Wan2.2开箱即用镜像:0配置部署,1块钱起体验最新模型

Wan2.2开箱即用镜像&#xff1a;0配置部署&#xff0c;1块钱起体验最新模型 你是不是也遇到过这种情况&#xff1a;刚听说Wan2.2发布了新版本&#xff0c;支持更长视频、更高清画质&#xff0c;心里一激动就想马上试试看。结果一打开GitHub仓库&#xff0c;发现依赖复杂、环境…

Qwen-Image-Edit-2511智能修图入门:5分钟云端体验,零技术门槛

Qwen-Image-Edit-2511智能修图入门&#xff1a;5分钟云端体验&#xff0c;零技术门槛 你是不是也经常遇到这样的情况&#xff1a;拍了一张特别满意的照片&#xff0c;但总觉得哪里差点意思——光线暗了点、背景太杂乱、人物表情不够自然&#xff1f;以前想修图&#xff0c;得装…

2026最新指南:作业帮下载安装全流程详解与实用技巧

前言 在智能教育快速发展的今天&#xff0c;学习类应用已成为学生和家长常用的学习工具。其中&#xff0c;作业帮凭借强大的题库资源与实时互动功能&#xff0c;深受广大学生群体欢迎。对于想要使用该应用的用户&#xff0c;如何安全、便捷地完成【作业帮下载安装】&#xff0…

BGE-Reranker-v2-m3快速原型开发:云端IDE+GPU,效率翻倍

BGE-Reranker-v2-m3快速原型开发&#xff1a;云端IDEGPU&#xff0c;效率翻倍 你是不是也经历过这样的场景&#xff1f;参加一场黑客马拉松&#xff0c;时间只有24小时&#xff0c;结果光是本地环境配置就花了6个小时——Python版本不对、CUDA驱动不兼容、模型依赖库缺失……等…