day11|150. 逆波兰表达式求值 239. 滑动窗口最大值 347.前 K 个高频元素

news/2026/1/25 21:38:41/文章来源:https://www.cnblogs.com/ounijiangovo/p/19530551

150. 逆波兰表达式求值

150. 逆波兰表达式求值 | 代码随想录

栈的最后表演! | LeetCode:150. 逆波兰表达式求值_哔哩哔哩_bilibili

笔记

逆波兰式表达式就是二叉树的左右中遍历顺序;我们正常看见的表达式就是左中右的遍历顺序

实操出现问题

string转化为int/long/long long stoi stol stoll

把char转换为int:如果 ch_char是一个数字字符('0' 到 '9'),想得到它代表的整数值(0 到 9),通常用 int num = ch_char - '0';。这是因为数字字符在 ASCII 表中是连续排列的,减去 '0' 的 ASCII 码就得到了对应的数值。

代码/比较

class Solution {
public:int evalRPN(vector<string>& tokens) {stack<long long> m_stack;for(int i=0;i<tokens.size();i++){if(tokens[i]=="+"||tokens[i]=="-"||tokens[i]=="*"||tokens[i]=="/"){long long nums1=m_stack.top();//减数/除数m_stack.pop();long long nums2=m_stack.top();//被减数/被除数m_stack.pop();if(tokens[i]=="+")m_stack.push(nums1+nums2);if(tokens[i]=="*")m_stack.push(nums1*nums2);if(tokens[i]=="/")m_stack.push(nums2/nums1);if(tokens[i]=="-")m_stack.push(nums2-nums1);}elsem_stack.push(stoll(tokens[i]));}return m_stack.top();}
};

**239. 滑动窗口最大值 **

单调队列正式登场!| LeetCode:239. 滑动窗口最大值_哔哩哔哩_bilibili

239. 滑动窗口最大值 | 代码随想录

笔记:

队列中的出口处是最大值;

我的队列怎么保证出口处一定是最大:对于push操作:现在要处理的数据如果比队尾的大,那么我的队列没有必要继续维护这个队尾了,将队尾移除,不停移除直到现在我的队尾数据比我现在处理的数要大。对于pop操作,当且仅当轮到pop这个数据的时候我再弹出数据。

实操出现问题:

1.vector的访问方式:空向量不能通过下标直接访问,必须用 push_back()或先 resize()

2.C++中deque的用法(超详细,入门必看)_c++ deque-CSDN博客

代码/比较:

class Solution {
private:
class mydeque{public:deque<int> m_deque;//入队的时候要考察大小,如果比队尾的大,则把队尾的元素出队后再将元素入队void push(int val){while(m_deque.empty()!=1&&val>m_deque.back())m_deque.pop_back();m_deque.push_back(val);}//只有当出队的元素等于队头的元素时才弹出void pop(int val){if(m_deque.empty()!=1&&val==m_deque.front())m_deque.pop_front();}int get_max(){return m_deque.front();}
};public:vector<int> maxSlidingWindow(vector<int>& nums, int k) {vector<int> result;//结果数组mydeque m_deque1;//先将前三个放进去for(int i=0;i<k;i++)m_deque1.push(nums[i]);//从第四个数据开始遍历,得到result值for(int i=k;i<nums.size();i++){result.push_back(m_deque1.get_max());m_deque1.push(nums[i]);m_deque1.pop(nums[i-k]);}//注意,此时最后一个窗口还没得到最大值result.push_back(m_deque1.get_max());return result;}
};

**239. 滑动窗口最大值 **

优先级队列正式登场!大顶堆、小顶堆该怎么用?| LeetCode:347.前 K 个高频元素_哔哩哔哩_bilibili

347.前 K 个高频元素 | 代码随想录

笔记:

小顶堆/大顶堆/优先级队列:

优先级队列就是一个披着队列外衣的堆,他功能强大在于 能够自动排序

基本语法和相关资料如下

【原创】优先队列 priority_queue 详解-CSDN博客

C++ 容器类 | 菜鸟教程

堆是一棵完全二叉树,树中每个结点的值都不小于(或不大于)其左右孩子的值。 如果父亲结点是大于等于左右孩子就是大顶堆,小于等于左右孩子就是小顶堆。

本题使用小顶堆还是大顶堆?如果定义一个大小为k的大顶堆,在每次移动更新大顶堆的时候,每次弹出都把最大的元素弹出去了,无法保留高频元素

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1215853.shtml

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

相关文章

求多个乘法逆元(模板)

线性算法 用于求一连串数字对于一个modp的逆元。洛谷P3811 只能用这种方法&#xff0c;别的算法都比这些要求一串要慢。 首先我们有一个,1−1≡1(modp) 然后设 pk∗ir,(1<r<i<p) 也就是 k 是 p/i 的商&#xff0c;r 是余数 。 再将这个式子放到(modp)意义下就会得…

语义分割实战——基于EGEUNet神经网络印章分割系统3:含训练测试代码、数据集和GUI交互界面

第一步&#xff1a;准备数据 印章分割-深度学习图像分割数据集 印章分割数据&#xff0c;可直接应用到一些常用深度学习分割算法中&#xff0c;比如FCN、Unet、SegNet、DeepLabV1、DeepLabV2、DeepLabV3、DeepLabV3、PSPNet、RefineNet、HRnet、Mask R-CNN、Segformer、DUCK-…

语义分割实战——基于EGEUNet神经网络印章分割系统2:含训练测试代码和数据集

第一步&#xff1a;准备数据 印章分割-深度学习图像分割数据集 印章分割数据&#xff0c;可直接应用到一些常用深度学习分割算法中&#xff0c;比如FCN、Unet、SegNet、DeepLabV1、DeepLabV2、DeepLabV3、DeepLabV3、PSPNet、RefineNet、HRnet、Mask R-CNN、Segformer、DUCK-…

语义分割实战——基于EGEUNet神经网络印章分割系统1:数据集说明(含下载链接)

印章分割-深度学习图像分割数据集 印章分割数据&#xff0c;可直接应用到一些常用深度学习分割算法中&#xff0c;比如FCN、Unet、SegNet、DeepLabV1、DeepLabV2、DeepLabV3、DeepLabV3、PSPNet、RefineNet、HRnet、Mask R-CNN、Segformer、DUCK-Net模型等 数据集总共有2000对…

强烈安利!本科生毕业论文必备TOP8 AI论文网站测评

强烈安利&#xff01;本科生毕业论文必备TOP8 AI论文网站测评 2026年本科生论文写作工具测评&#xff1a;为什么你需要这份榜单&#xff1f; 随着人工智能技术的不断进步&#xff0c;越来越多的本科生开始借助AI工具提升论文写作效率。然而&#xff0c;面对市场上五花八门的论…

STM32F0实战:基于HAL库开发【2.3】

9.2.1 事件线概述 在EXTI中引入了“事件”这一概念。与中断相比,事件的产生不会中断主程序的进程,但可以让处于功耗管理模式下的微控制器唤醒。EXTI管理的异步事件和中断包括以下两类。 来自引脚的外部中断/事件:这类中断和事件大多与GPIO相关联,涉及端口引脚的输入或输出…

工信部教考中心《系统可靠性工程师(高级)》开课通知

系统可靠性工程师&#xff08;高级&#xff09;课程背景当“系统宕机”就能冲上热搜、一次故障足以抹去全年利润时&#xff0c;可靠性不再是运维部的“幕后工作”&#xff0c;而是决定企业生死的“前沿战场”。工信部教考中心推出的《系统可靠性工程师&#xff08;高级&#xf…

机房U位管理别瞎忙!这套系统让运维效率翻倍

作为常年深耕机房运维领域的博主&#xff0c;后台最多的吐槽莫过于U位管理的糟心事&#xff1a;“机柜里U位乱得像麻花&#xff0c;找个位置要扒半天线缆”“人工登记的U位信息过时&#xff0c;新增设备误占用引发故障”“跨机柜调配资源&#xff0c;来回核对耗时耗力”……机房…

告别设备束缚 RetroArch-web 把童年游戏装进口袋,cpolar解锁全场景游玩

RetroArch-web 作为一款网页版复古游戏模拟器集合&#xff0c;核心功能是将 FC、SFC、PS、GBA 等数十种经典游戏机的体验整合到浏览器中&#xff0c;无需复杂配置&#xff0c;上传游戏 ROM 即可游玩&#xff0c;适配 Windows、macOS、Android、iOS 等所有带浏览器的设备&#x…

使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--Pytest框架钩子函数

测试学习记录&#xff0c;仅供参考&#xff01;Pytest框架钩子函数钩子函数在 pytest 框架中是一个比较重要的概念&#xff1b;在测试执行前、或测试执行过程中在前置功能里面做一些操作&#xff1b;可以自定义钩子函数&#xff1b;一、钩子函数在Pytest框架中&#xff0c;钩子…

使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 43--添加allure测试报告显示信息和其他封装方法

测试学习记录&#xff0c;仅供参考&#xff01; 添加allure测试报告显示信息 增加测试报告首页环境信息和修改 allure 测试报告显示图标&#xff1b; 一、增加测试报告首页环境信息 1、在项目根目录下创建一个名称为 environment.xml 的配置文件&#xff0c;输入相关的环境配置…

云端VS本地 RFID资产管理系统怎么选?优缺点大揭秘

一、开篇&#xff1a;资产 “迷路”&#xff1f;RFID 系统部署抉择是关键 1.1 传统资产管理的 “老大难” 痛点 家人们&#xff0c;在企业的日常运营里&#xff0c;资产管理要是没做好&#xff0c;那可真是麻烦不断&#xff01;就说传统的人工盘点方式&#xff0c;简直就是一…

Transactional失效的情况总结

@Transactional失效的情况总结 前言 @Transactional失效是实际开发中非常容易踩的坑,本文结合实际项目经验总结了常见的失效场景和解决方案。一、最常见的:同类内部调用(占80%的坑) 这是最容易犯的错误,也是开发中…

Spark GIS:分布式计算框架下的空间数据分析

Spark GIS实战&#xff1a;用分布式计算破解大规模空间数据处理难题 副标题&#xff1a;基于GeoSpark的空间查询、分析与可视化全流程指南 摘要/引言 问题陈述 你是否遇到过这样的困境&#xff1f;用ArcGIS处理10GB的GPS轨迹数据时&#xff0c;软件崩溃了3次&#xff1b;用…

2023年NOC大赛创客智慧编程赛项Python复赛模拟题(一)

更多内容和历年真题请查看网站&#xff1a;【试卷中心 -----> NOC ----> Python ----> 复赛】 网站链接 青少年软件编程历年真题模拟题实时更新 2023年NOC大赛创客智慧编程赛项Python复赛模拟题&#xff08;一&#xff09; 一、编程题 第 1 题 NOC大赛创客智慧…

2023年NOC大赛创客智慧编程赛项Python复赛模拟题(二)

更多内容和历年真题请查看网站&#xff1a;【试卷中心 -----> NOC ----> Python ----> 复赛】 网站链接 青少年软件编程历年真题模拟题实时更新 2023年NOC大赛创客智慧编程赛项Python复赛模拟题&#xff08;二&#xff09; 一、编程题 第 1 题 NOC大赛创客智慧编程…

Python大数据项目推荐:基于Hadoop+Spark电商用户行为分析毕设 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡如果你遇到具体的…

Flutter for OpenHarmony 剧本杀组队App实战22:快速匹配功能实现

引言 快速匹配功能帮助用户自动寻找合适的队伍&#xff0c;无需手动浏览组队列表。本篇将实现带有匹配动画的快速匹配页面。快速匹配是现代社交应用的重要功能&#xff0c;通过算法自动配对用户&#xff0c;大大提升了用户体验和应用的活跃度。这个功能特别适合剧本杀组队场景…

【计算机毕设选题】基于Spark的双十一美妆数据可视化系统源码 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡如果你遇到具体的…

Reap

Reap (/riːp/) is a verb. Its core concept revolves around *1) to cut and gather a crop; 2) to receive something as a consequence of your actions. It connects ideas of harvesting, effort, and conseque…