【练习】【栈】牛客NC212914牛牛与后缀表达式

devtools/2025/3/4 2:27:17/

题目

给定牛牛一个后缀表达式s,计算它的结果,例如,1+1对应的后缀表达式为1#1#+,‘#’作为操作数的结束符号。
其中,表达式中只含有‘+’、’-‘、’*‘三种运算,不包含除法。 本题保证表达式一定合法,且计算过程和计算结果的绝对值一定不会超过10^18

示例1

输入

“1#1#+”

返回值

2

示例2

输入

“12#3#+15#*”

返回值

225

来源:牛客NC212914牛牛与后缀表达式


思路(注意事项)

此题模板与acwing表达式求值模板类似,但是比那道题简单很多,不用考虑符号优先级、不用额外处理括号、不用额外的来存放符号。前面这题做会,这道题就是小菜一碟。


纯代码

class Solution {
private:stack<long long> num;void eval(char c){long long a, b,ans;a = num.top();num.pop();b = num.top();num.pop();if (c == '+') ans = a + b;else if (c == '-') ans = b - a;else if (c == '*') ans = b * a;num.push(ans);}
public:long long legalExp(string str) {for (int i = 0; i < str.size(); i ++){if (isdigit(str[i])){long long x = 0, j = i;while (j < str.size() && str[j] != '#'){x = x * 10 + str[j] - '0';j ++;}num.push(x);i = j - 1;}else if (str[i] == '#') continue;else eval(str[i]);}return num.top();}
};

题解(加注释)

#include <stack>
#include <string>
#include <cctype>// 定义一个解决方案类,用于处理后缀表达式的计算
class Solution {
private:// 定义一个存储长整型的,用于存放操作数std::stack<long long> num;// 该函数用于执行具体的运算操作// 参数 c 为运算符void eval(char c){// 定义三个长整型变量,a 和 b 用于存储操作数,ans 用于存储运算结果long long a, b, ans;// 从中取出顶元素作为第一个操作数a = num.top();// 取出后将该元素从中移除num.pop();// 再从中取出顶元素作为第二个操作数b = num.top();// 取出后将该元素从中移除num.pop();// 根据运算符 c 进行不同的运算if (c == '+') {// 若为加法运算符,将两个操作数相加得到结果ans = a + b;} else if (c == '-') {// 若为减法运算符,用第二个操作数减去第一个操作数得到结果ans = b - a;} else if (c == '*') {// 若为乘法运算符,将两个操作数相乘得到结果ans = b * a;}// 将运算结果压入num.push(ans);}
public:// 该函数用于计算后缀表达式的值// 参数 str 为后缀表达式字符串// 返回值为计算得到的结果,类型为长整型long long legalExp(std::string str) {// 遍历后缀表达式字符串中的每个字符for (int i = 0; i < str.size(); i++){// 判断当前字符是否为数字if (std::isdigit(str[i])){// 若为数字,初始化一个长整型变量 x 用于存储该数字的值long long x = 0;// 定义一个临时变量 j 用于从当前位置开始向后扫描数字int j = i;// 当未扫描到字符串末尾且当前字符不是分隔符 '#' 时while (j < str.size() && str[j] != '#'){// 将之前的数字乘以 10 并加上当前字符对应的数字值x = x * 10 + (str[j] - '0');// 指针向后移动一位j++;}// 将完整的数字压入操作数num.push(x);// 由于 while 循环结束后 j 已经指向下一个非数字字符,所以将 i 更新为 j - 1// 以便 for 循环的 i++ 能正确处理下一个字符i = j - 1;} // 若当前字符为分隔符 '#'else if (str[i] == '#') {// 跳过该字符,继续处理下一个字符continue;} // 若当前字符为运算符else {// 调用 eval 函数进行相应的运算eval(str[i]);}}// 遍历结束后,顶元素即为后缀表达式的计算结果,将其返回return num.top();}
};

http://www.ppmy.cn/devtools/164342.html

相关文章

【大模型系列篇】DeepSeek开源周,解锁AI黑科技

&#x1f525; Day1&#xff1a;FlashMLA —— GPU推理加速器 专为处理长短不一的AI推理请求而生&#xff0c;就像给Hopper GPU装上了智能导航&#xff0c;让数据在芯片上跑出3000GB/s的"磁悬浮"速度。✅ 已支持BF16格式&#xff5c;580万亿次浮点运算/秒FlashMLA G…

通过Nginx负载均衡+Keepalived实现业务高可用

通过Nginx负载均衡和Keepalived可以实现业务的高可用&#xff0c;以下是详细的实现步骤&#xff1a; 环境准备 假设我们有3台服务器&#xff0c;IP地址分别为&#xff1a; 服务器1&#xff08;Nginx Keepalived 主节点&#xff09;&#xff1a;192.168.1.100服务器2&#x…

Spring IOC DI

前言 继续复习&#xff0c;继续补博客&#xff0c;继续努力&#xff0c;继续温故知新。 IoC 与 DI 入门 在 Java 开发领域&#xff0c;Spring 框架无疑占据着举足轻重的地位。其中&#xff0c;IoC&#xff08;控制反转&#xff09;和 DI&#xff08;依赖注入&#xff09;更是…

【R语言】加权回归拟合

# 导包library(ggplot2)library(stats)# 创建数据集set.seed(233)x <- seq(0, 10, by 0.2) #0-10步长为0.2y <- sin(x) rnorm(length(x), mean 0, sd 0.2) #均值为0、标准差为0.2的正态分布data <- data.frame(x, y)# 设置局部加权回归带宽参数bandwidth <- 0.…

【vue-echarts】——01.认识echarts

文章目录 前言一、echarts二、使用步骤1.vue cli创建项目并安装第三方模块echarts2.显示图表总结前言 定制的数据可视化图表。ECharts最初由百度团队开源,并于2018年初捐赠给Apache基金会,成为ASF孵化级项目。2021年1月26日晚,Apache基金会官方宣布ECharts项目正式毕业。 一…

windows同时安装两个不同版本的Mysql

文章目录 目录 ?文章目录 前言 一、MySql下载 1、 官网下载&#xff1a; 2、 解压文件 3、 新建my.ini文件。 二、配置MySql环境变量 1、新建系统环境变量 ?三、MySql安装 1、进入MySql的bin目录 ?2、安装MySql服务 3、修改登录密码、并自动创建data文件夹 4、…

SQLark 数据迁移|断点续迁已上线(Oracle-达梦)

数据迁移是 SQLark 最受企业和个人用户欢迎的功能之一&#xff0c;截止目前已帮助政府、金融、能源、通信等 50 家单位完成从 Oracle、MySQL 到达梦的全量迁移&#xff0c;自动化迁移成功率达 96% 以上。 在 Oracle 到达梦数据库迁移过程中&#xff0c;SQLark V3.3 新增 断点续…

(七)消息队列-Kafka 序列化avro(传递)

&#xff08;七&#xff09;消息队列-Kafka 序列化avro&#xff08;传递&#xff09; 客从远方来&#xff0c;遗我双鲤鱼。呼儿烹鲤鱼&#xff0c;中有尺素书。 ——佚名《饮马长城窟行》 本文已同步CSDN、掘金平台、知乎等多个平台&#xff0c;图片依然保持最初发布的水印&…