算法笔记(九)——栈
文章目录
- 删除字符串中的所有相邻重复项
- 比较含退格的字符串
- 基本计算机II
- 字符串解码
- 验证栈序列
栈是一种
先进后出
的数据结构,其操作主要有
进栈、压栈(Push)
出栈(Pop)
常见的使用栈的算法题
- 中缀转后缀
- 逆波兰表达式求值
- 括号匹配
- 深度优先搜索
删除字符串中的所有相邻重复项
题目:删除字符串中的所有相邻重复项
思路
- 用栈的思想来模拟
- 遍历字符串,如果栈为空或栈顶元素和进栈元素不相同,字符进栈
- 否则,即栈顶元素和进栈元素相同,则
pop
栈顶元素 - 但是,最后留在栈中的字符就是需要返回的,并且是逆序的,所以我们直接用原来的字符串模拟栈
C++代码
class Solution
{
public:string removeDuplicates(string s) {string res;for(auto ch : s){if(res.size() && res.back() == ch) res.pop_back();else res.push_back(ch);}return res;}
};
比较含退格的字符串
题目:比较含退格的字符串
思路
- 利用栈的思想,封装一个
check
函数来返回退格后的字符串 chech
函数的实现:- 遍历字符串,如果不是
#
,直接加到res
上;否则,如果res
中没有元素,但是遇到了#
,直接跳过不用pop_back()
C++代码
class Solution
{
public:string check(string &s){string res;for(auto ch : s){if(ch != '#') res += ch; // 如果不是‘#’。直接加到res上else{if(res.size()) // 如果res中没有元素,但是遇到了‘#’,应该直接跳过不用pop_back()res.pop_back();} }return res;}bool backspaceCompare(string s, string t) {return check(s) == check(t); // 检查退格后的字符串是否相等}
};
基本计算机II
题目:基本计算器 II
思路
- 由于运算符只有
('+', '-', '*', '/')
这四种,我们使用一个数组来模拟栈,插入每一个数,使用一个前缀字符来进行运算符的标记,初始设为加; - 当操作符
op
遇到加减都更新,遇到乘除则与栈顶元素计算,遍历结束后,我们将栈中元素相加;
C++代码
class Solution
{
public:// 1. 遇到操作符,更新操作符op;// 2. 遇到数字;// 1>. 先将数字提取到tmp中// 2>. 根据op分类讨论// ①op == '+', tmp入栈// ②op == '-', -tmp入栈// ③op == '*', 直接和栈顶元素相×// ④op == '/', 直接和栈顶元素相÷int calculate(string s) {char op = '+';int i = 0, n = s.size();vector<int> v; // 模拟栈while(i < n){if(s[i] == ' ') i++;else if('0' <= s[i] && s[i] <= '9'){// 数字提取到tmp中int tmp = 0;while(i < n && '0' <= s[i] && s[i] <= '9')tmp = 10 * tmp + (s[i++] - '0');if(op == '+') v.push_back(tmp);else if(op == '-') v.push_back(-tmp);else if(op == '*') v.back() *= tmp;else v.back() /= tmp;}else {op = s[i];i++;}}int res = 0;for(auto x : v){res += x;}return res;}
};
字符串解码
题目:字符串解码
思路
- 定义两个栈一个字符串、一个int变量
- 遇到数字放入数字栈
- 遇到
[
,把后面的字符串提取、放入字符串栈 - 遇到
]
,取出两栈顶元素解析,放入字符串栈的栈顶元素后面 - 遇到字符, 提取字符,放入字符串栈的栈顶元素后面
C++代码
class Solution
{
public:// 两个栈一个字符串、一个int变量// 1. 遇到数字放入数字栈;// 2. 遇到'[',把后面的字符串提取、放入字符串栈// 3. 遇到']',取出两栈顶元素解析,放入字符串栈的栈顶元素后面// 4. 遇到字符, 提取字符,放入字符串栈的栈顶元素后面string decodeString(string s) {stack<string> ss;stack<int> si;int i = 0, n = s.size();ss.push("");while(i < n){if(s[i] >= '0' && s[i] <= '9') {int t = 0;while ('0' <= s[i] && s[i] <= '9')t = 10 * t + (s[i++] - '0');si.push(t);}else if(s[i] == '[') {i++;string t = "";while(s[i] >= 'a' && s[i] <= 'z')t += s[i++];ss.push(t);}else if(s[i] == ']'){string t = ss.top();ss.pop();int j = si.top();si.pop();while(j--){ss.top() += t;}i++; // 跳过右括号}else{string t = "";while(i < n && s[i] >= 'a' && s[i] <= 'z')t += s[i++];ss.top() += t;}}return ss.top();}
};
验证栈序列
题目:验证栈序列
思路
用一个栈来模拟这个过程,最后栈为空则说明相匹配,否则说明不匹配
- 用
i
来遍历pop
数组,确定要出栈的元素- 判断栈顶元素是否等于要出栈的元素,如果相等则出栈,并
i++
到下一个要出栈的元素上
class Solution
{
public:bool validateStackSequences(vector<int>& pushed, vector<int>& popped) {stack<int> s;int n = popped.size();int i = 0; // 标志位:确定要出栈的元素for(auto ch : pushed){s.push(ch);// 判断栈顶元素是否等于要出栈的元素,如果相等则出栈,并将标志位挪到下一个要出栈的元素上while(s.size() && s.top() == popped[i]) {s.pop();i++;}}return s.empty(); }
};
相关文章:

算法笔记(九)——栈
文章目录 删除字符串中的所有相邻重复项比较含退格的字符串基本计算机II字符串解码验证栈序列 栈是一种先进后出的数据结构,其操作主要有 进栈、压栈(Push) 出栈(Pop) 常见的使用栈的算法题 中缀转后缀逆波兰表达式求…...

动态SLAM总结一
文章目录 方法分类:OctoMap:(2013)UFOMap:(2020)Removert:(2020)ERASOR:(2021)DynamicFilter:(202…...

HTB:Mongod[WriteUP]
连接至HTB服务器并启动靶机 靶机IP:10.129.99.33 分配IP:10.10.16.12 1.How many TCP ports are open on the machine? 使用nmap对靶机进行全端口TCP脚本、服务扫描: nmap -sC -sV -T4 -p- {TARGET_IP} 可以看到靶机共开放TCP端口2个&…...

DenseNet算法:口腔癌识别
本文为为🔗365天深度学习训练营内部文章 原作者:K同学啊 一 DenseNet算法结构 其基本思路与ResNet一致,但是它建立的是前面所有层和后面层的密集连接,它的另一大特色是通过特征在channel上的连接来实现特征重用。 二 设计理念 三…...

828华为云征文 | 利用FIO工具测试Flexus云服务器X实例存储性能
目录 一、Flexus云服务器X实例概要 1.1 Flexus云服务器X实例摘要 1.2 产品特点 1.3 存储方面性能 1.4 测评服务器规格 二、FIO工具 2.1 安装部署FIO 2.2 主要性能指标概要 三、进行压测 3.1 测试全盘随机读IO延迟 3.2 测试全盘随机写IO延迟 3.3 测试随机读IOPS 3.4…...

Pikachu-File Inclusion- 本地文件包含
前端每次挑选篮球明星,都会通过get请求,传了文件名,把页面展示出来,由于文件名时前端传给后台;并且查看源码,没有对参数做限制; 尝试直接从前端修改filename 参数; filename../../../../../../…...

linux基础 超级笔记
1.Linux系统的组成 Linux系统内核:提供系统最核心的功能,如软硬件和资源调度。 系统及应用程序:文件、任务管理器。 2.Linux发行版 通过修改内核代码自行集成系统程序,即封装。比如Ubuntu和centos这种。不过基础命令是完全相…...

Python——异常处理机制
Python 异常处理机制 Python异常与异常处理机制针对 Traceback 的解读try-except-else-finallyexcept语句except语句的机制在 except 语句中引用当前被处理的 Python 异常 finally语句finally语句执行后才能抛出未被处理的异常finally中执行return会导致异常丢失 raise 语句rai…...

社群团购中的用户黏性价值:以开源小程序多商户AI智能名片商城源码为例
摘要:本文探讨社群团购中的用户黏性价值,分析其与传统团购网站的区别,并阐述开源小程序多商户AI智能名片商城源码在增强社群团购用户黏性方面可能发挥的作用。 一、引言 在当今的商业环境中,社群团购逐渐成为一种重要的营销模式。…...

基于php的民宿预订管理系统
作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码 精品专栏:Java精选实战项目…...

java 从基础到入门 到架构师所需要学习的路线
java是一种广泛使用的编程语言,可以应用于多种平台和应用程序。下面是一个从基础到入门,再到架构师所要掌握的Java学习路线的详细列举: 学习Java基础知识: 理解面向对象编程的概念,如类、对象、继承、多态等。 学习Ja…...

【吊打面试官系列-MySQL面试题】什么叫视图?游标是什么?
大家好,我是锋哥。今天分享关于【什么叫视图?游标是什么?】面试题,希望对大家有帮助; 什么叫视图?游标是什么? 视图是一种虚拟的表,具有和物理表相同的功能。可以对视图进行增&#…...

项目管理-信息技术发展
1、计算机软硬件 2、计算机网络 1)定义 2)分类:PAN LAN MAN WAN 公用网 专用网 3)网络协议 语法 语义 时许 4)网络标准协议 7层 5)IEEE 802 规范 6)TCP/IP 协议 7) SDN 软件定义网…...

异常处理【C++提升】(基本思想,重要概念,异常处理的函数机制、异常机制,栈解旋......你想要的全都有)
更多精彩内容..... 🎉❤️播主の主页✨😘 Stark、-CSDN博客 本文所在专栏: C系列语法知识_Stark、的博客-CSDN博客 座右铭:梦想是一盏明灯,照亮我们前行的路,无论风雨多大,我们都要坚持不懈。 异…...

基于springboot vue 电影推荐系统
博主介绍:专注于Java(springboot ssm 等开发框架) vue .net php python(flask Django) 小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设,从业十五余年开发设计教学工作☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找…...

八、特殊类型异常机制
特殊类型&异常机制 数据类型枚举类型匿名类、单例类和伴生对象匿名类单例类伴生对象 委托模式密封类型异常机制异常的使用异常的处理 数据类型 对于那些只需要保存数据的类型,我们常常需要为其重写toString、equals等函数,针对于这种情况下…...

虾皮Shopee Android面试题及参考答案
HTTP 状态码有哪些? HTTP 状态码是用以表示网页服务器超文本传输协议响应状态的 3 位数字代码。主要分为五大类: 1xx 信息性状态码:表示服务器正在处理请求,这些状态码是临时的响应,主要用于告诉客户端请求已经被接收,正在处理中。例如,100 Continue 表示客户端应当继续…...

Docker Compose 部署大模型GPU集群:高效分配与管理算力资源
Docker Compose 部署大模型GPU集群:高效分配与管理算力资源 文章目录 Docker Compose 部署大模型GPU集群:高效分配与管理算力资源一 Dockerfile 编写二 Dockerfile 示例三 分配GPU资源1)GPU分配:指定count2)GPU分配&am…...

直立行走机器人技术概述
直立行走机器人技术作为现代机器人领域的重要分支,结合了机械工程、计算机科学、人工智能、传感技术和动态控制等领域的最新研究成果。随着技术的不断发展,直立行走机器人在救灾、医疗、家庭辅助等领域开始发挥重要作用。本文旨在对直立行走机器人的相关…...

【Linux】wsl虚拟机时间和实际时间不符合
本文首发于 ❄️慕雪的寒舍 偶然遇到了这个问题,触发原因是电脑在开启wsl的情况下进入了 休眠 模式,且在无网络情况下几天不使用。 然后开启wsl,发现git log显示最新commit的提交时间是明天,给我吓一跳,然后才发现原来…...

初识算法 · 滑动窗口(1)
目录 前言: 长度最小的子数组 题目解析 算法原理 算法编写 无重复长度的最小字符串 题目解析 算法原理 算法编写 前言: 本文开始,介绍的是滑动窗口算法类型的题目,滑动窗口本质上其实也是双指针,但是呢&#…...

nginx和gateway的关系和区别
在技术选型时,选择 Nginx 和 Spring Cloud Gateway(或简称为 Gateway)主要取决于具体应用场景和技术需求。下面是两者的一些关键差异和适用场景。 一、Nginx 概念 Nginx 是一个高性能的 Web 服务器和反向代理服务器,常被用作静…...

【算法笔记】滑动窗口算法原理深度剖析
【算法笔记】滑动窗口算法原理深度剖析 🔥个人主页:大白的编程日记 🔥专栏:算法笔记 文章目录 【算法笔记】滑动窗口算法原理深度剖析前言一.长度最小的子数组1.1题目1.2思路分析1.3算法流程1.4正确性证明1.5代码实现 二.无重复…...

4S店4S店客户管理系统小程序(lw+演示+源码+运行)
社会的发展和科学技术的进步,互联网技术越来越受欢迎。手机也逐渐受到广大人民群众的喜爱,也逐渐进入了每个用户的使用。手机具有便利性,速度快,效率高,成本低等优点。 因此,构建符合自己要求的操作系统是非…...

rabbitMq------连接管理模块
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言管理的字段连接内存管理对象 前言 我们的网络通信框架使用的muduo库,而在mudu库中是已经有了连接的概念,但是我们呢还有一个信道的概念…...

【部署项目】禹神:前端项目部署上线笔记
1.项目打包 ● 我们开发用的脚手架其实就是一个微型服务器,用于:支撑开发环境、运行代理服务器等。 ● 打包完的文件中不存在:.vue、.jsx、.less 等文件,而是:html、css、js等。 ● 打包后的文件,不再借助…...

力扣10.1
983. 最低票价 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行。在接下来的一年里,你要旅行的日子将以一个名为 days 的数组给出。每一项是一个从 1 到 365 的整数。 火车票有 三种不同的销售方式 : 一张 为期一天 的通行证售…...

TypeScript 算法手册 - 【冒泡排序】
文章目录 TypeScript 算法手册 - 冒泡排序1. 冒泡排序简介1.1 冒泡排序定义1.2 冒泡排序特点 2. 冒泡排序步骤过程拆解2.1 比较相邻元素2.2 交换元素2.3 重复过程 3. 冒泡排序的优化3.1 提前退出3.2 记录最后交换位置案例代码和动态图 4. 冒泡排序的优点5. 冒泡排序的缺点总结 …...

计算机网络——http和web
无状态服务器——不维护客户端 怎么变成有状态连接 所以此时本地建立代理—— 若本地缓存了——但是服务器变了——怎么办?...

使用 Light Chaser 进行大屏数据可视化
引言 在当今数据驱动的世界中,数据可视化变得越来越重要。Light Chaser 是一款基于 React 技术栈的大屏数据可视化设计工具,通过简单的拖拽操作,你可以快速生成漂亮、美观的数据可视化大屏和看板。本文将介绍如何使用 Light Chaser 进行数据…...