贤鱼的刷题日常(数据结构栈学习)-1696:波兰表达式--(递归+栈双题解)题目详解

news2025/1/10 18:23:58

🏆今日学习目标:
🍀例题讲解1696:波兰表达式
✅创作者:贤鱼
⏰预计时间:25分钟
🎉个人主页:贤鱼的个人主页
🔥专栏系列:c++
🍁贤鱼的个人社区,欢迎你的加入 贤鱼摆烂团

请添加图片描述

61696:波兰表达式

  • 题目
  • 思路
  • AC代码

题目

总时间限制: 1000ms 内存限制: 65536kB

  • 描述
    波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3的波兰表示法为+ 2 3。波兰表达式的优点是运算符之间不必有优先级关系,也不必用括号改变运算次序,例如(2 + 3) * 4的波兰表示法为* + 2 3 4。本题求解波兰表达式的值,其中运算符包括+ - * /四个。

  • 输入
    输入为一行,其中运算符和运算数之间都用空格分隔,运算数是浮点数。

  • 输出
    输出为一行,表达式的值。
    可直接用printf(“%f\n”, v)输出表达式的值v。

  • 样例输入

+ 11.0 12.0 + 24.0 35.0
  • 样例输出
1357.000000
  • 提示
    可使用atof(str)把字符串转换为一个double类型的浮点数。atof定义在math.h中。
    此题可使用函数递归调用的方法求解。

思路

递归思路不讲了很简单一看就会
栈的思路就是结构体储存记录符号和数字,遇到数字入栈,遇到符号计算,由于前缀表达式,直接顺序记录最后倒序处理就好了

AC代码

#include<cmath>
#include<cstdio>
#include<iostream>
using namespace std;
char m[100000];
double js(){
	scanf("%s",m+1);
	switch(m[1]){
		case '+':return js()+js();break;
		case '-':return js()-js();break;
		case '*':return js()*js();break;
		case '/':return js()/js();break;
		default:return atof(m+1);
	}
}
int main(){
	printf("%lf",js());
}
#include<cmath>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<stack>
#include<bits/stdc++.h>
using namespace std;
stack<double>nm;
char s[10005];
struct node{
	char f;
	double m;
}a[10005];
double cl(double xx,double yy,char t){
	switch(t){
		case'+':return xx+yy;
		case'-':return yy-xx;
		case'*':return xx*yy;
		default:return yy/xx;
	}
}
int cnt=0;
double js(){
	for(int i=cnt;i>=1;i--){
		if(a[i].f=='\0'){
			nm.push(a[i].m);
		}else{
			double x=nm.top();
			nm.pop();
			double y=nm.top();
			nm.pop();
			nm.push(cl(y,x,a[i].f));
		}
	}
	return nm.top();
}
int main(){
	while(scanf("%s",s)!=EOF){
		if((s[0]>='0'&&s[0]<='9')||(s[1]>='0'&&s[1]<='9')){
			a[++cnt].m=atof(s);
			a[cnt].f='\0';
		}else{
			a[++cnt].f=(s[0]);
			a[cnt].m=0;
		}
	}
	printf("%lf\n",js());
}

请添加图片描述

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

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

相关文章

MySQL用户管理详解

文章目录 用户管理创建用户更改密码mysql的权限分类授权实例撤销权力 mysql检查顺序相关文件信息 用户管理 创建用户 在MySQL中&#xff0c;创建用户是管理和授权数据库访问权限的重要操作。下面是创建用户的详细步骤&#xff1a; 连接到MySQL服务器&#xff1a;使用MySQL客户…

人员定位安全管控系统:提升安全管理水平的智能解决方案

在当今社会&#xff0c;人员安全管理成为各行各业关注的焦点。为了保障人员的安全和提高管理效率&#xff0c;人员定位安全管控系统应运而生。 人员定位安全管控系统采用多种定位技术来实现对人员位置的准确定位&#xff0c;如GPS&#xff08;全球定位系统&#xff09;、Wi-Fi…

强化学习论文《Deep Reinforcement Learning that Matters》笔记

文章目录 1. 简介2. 实验分析超参数网络架构Reward ScaleRandom Seeds and TrailsEnvironmentCodebases 3. Reporting Evaluation MetricsOnline view vs. Policy OptimizationConfidence BoundsPower AnalysisSignificance 4. 结论5. 参考资料 1. 简介 这篇2017年的论文 是强化…

【PHP】phpstudy添加的网站,访问出现 嗯… 无法访问此页面

使用phpstudy创建网站&#xff0c;只有localhost可以访问&#xff0c; 其他所有网站无法访问&#xff0c;可能是你的账户没有修改vhost的权限 找到 C:\Windows\System32\drivers\etc下的vhost文件&#xff0c; 1、右键属性 将只读去掉 2、把用户对此文件的控制权限全部勾上 …

解决直播间源码音视频不同步问题的有效方式

随着网络技术的发展和移动设备的普及&#xff0c;电视、电脑、手机等数码产品越来越智能&#xff0c;我们不管是在家或是在外面都可以运用不同的数码产品去看剧或是短视频等&#xff0c;但可能很多人遇到过这样一种情况&#xff1a;当我们在看剧或是短视频的时候&#xff0c;可…

微信小程序可输入弹窗

addWhite() {wx.showModal({title: 添加白名单,editable: true, // 可输入content: ,complete: (res) > {if (res.confirm) {if (!res.content) { // 输入的值wx.showToast({title: 请填写白名单,icon: error})this.addWhite()}else {// 调接口}}}})},

Linux命令-按照与使用(17)(转载)解决同一台服务器上部署多个tomcat的同一个项目session冲突问题...

———————————————— 版权声明&#xff1a;本文为CSDN博主「strive_or_die」的原创文章&#xff0c;遵循CC 4.0 BY-SA版权协议&#xff0c;转载请附上原文出处链接及本声明。 原文链接&#xff1a;https://blog.csdn.net/strive_or_die/article/details/103191546…

EXCEL模板如何自定义并使用?

文章目录 0.引言1.新建EXCEL2.EXCEL另存为模板3.使用模板 0.引言 使用Excel模板可以帮助用户更高效地处理和分析大量数据&#xff0c;简化重复任务&#xff0c;并提供清晰直观的数据可视化效果。对于需要频繁进行数据处理和分析的个人或组织来说&#xff0c;使用Excel模板是一个…

半导体自动化专用除静电设备的特点和功能

半导体自动化专用离子风机是一种用于半导体制造过程中的特殊风机设备。它通过产生带电粒子&#xff08;离子&#xff09;的气流来实现静电去除和除尘&#xff0c;以确保半导体制造环境的洁净和无尘。 以下是半导体自动化专用离子风机的一些特点和功能&#xff1a; 1. 静电去除…

听GPT 讲K8s源代码--pkg(七)

k8s项目中 pkg/kubelet/config&#xff0c;pkg/kubelet/configmap&#xff0c;pkg/kubelet/container&#xff0c;pkg/kubelet/cri 这几个目录处理与 kubelet 配置、ConfigMap、容器管理和容器运行时交互相关的功能。它们共同构成了 kubelet 的核心功能&#xff0c;使其能够在 …

在外远程查看家里内网监控

在外远程查看家里内网监控 现代生活节奏紧张&#xff0c;巨大的压力压得我们喘不过气来&#xff0c;因此很多人选择在家里养一只陪伴我们的宠物&#xff0c;用以舒缓紧张的情绪和繁重的压力。但养了这些小家伙后&#xff0c;不在家时又总想随时看看家里小可爱们的情况&#xf…

STL:双端队列容器适配器仿函数优先级队列

deque 双端队列可以在头部和尾部进行插入删除操作与vector相比&#xff0c;头插效率高&#xff0c;不需要搬移元素 与list相比&#xff0c;空间利用率高 deque逻辑上空间是连续的&#xff0c;物理上并不是&#xff0c;是由一段段小空间拼接而成的 双端队列的迭代器比较复杂 cur…

Python爬虫技术及其原理详解

概要 随着互联网的发展&#xff0c;大量的数据被存储在网络上&#xff0c;而我们需要从中获取有用的信息。Python作为一种功能强大且易于学习的编程语言&#xff0c;被广泛用于网络爬虫的开发。本文将详细介绍Python爬虫所需的技术及其原理&#xff0c;并提供相关的代码案例。 …

Python—数据结构(一)

先放一张自己学习和整理归纳的思维导图&#xff0c;以便让大家都知道我自己的整体学习路线。 数据结构的学习路上内容枯燥&#xff0c;但坚持下来一定有很大的收获&#xff01;加油&#x1f4aa;&#x1f3fb;&#xff01; 数据结构 数据的概念数据元素&#xff1a; 若干基本…

php基于redis处理session的方法

php基于redis处理session的方法 一个基于redis的处理session的方法&#xff0c;如下&#xff1a; class Session_custom { private $redis; // redis实例 private $prefix sess_; // session_id前缀 // 会话开始时&#xff0c;会执行该方法&#xff0c;连接redis服务器 p…

【JVM】JVM执行流程 JVM类加载 垃圾回收机制等

目录 &#x1f337;1、JVM是什么&#xff1f; &#x1f337;2、JVM的执行流程&#xff08;能够描述数据区5部分&#xff09; &#x1f337;3、JVM类加载过程 &#x1f337;4、双亲委派机制&#xff1a;描述类加载的过程 问题1&#xff1a;类加载器 问题2&#xff1a;什么…

前端知识点视频补充

使用工具&#xff1a; Vscode使用&#xff1a; 需要下载插件&#xff1a;open in browser。这个插件可以快速打开浏览器。 选择文件夹有两种方式&#xff1a;选择打开文件、拖拽方式&#xff08;这种最方便&#xff09; 快捷键&#xff1a;快速生成Htm结构文件&#xff1a;…

msvcr100.dll丢失的解决方法

在解决msvcr100.dll丢失问题前&#xff0c;给大家介绍一下为什么msvcr100.dll会丢失 msvcr100.dll文件丢失的原因可能有多种。以下是一些常见的原因&#xff1a; 文件被误删&#xff1a;有时候&#xff0c;用户可能会误删除msvcr100.dll文件&#xff0c;导致其丢失。 文件损…

蓝桥杯专题-真题版含答案-【生命之树】【消除尾一】【密码脱落】【生日蜡烛】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

用户管理功能

后端 # 获取用户列表 bp.get("/user/list") def user_list():users UserModel.query.order_by(UserModel.join_time.desc()).all()user_list [user.to_dict() for user in users]return restful.ok(datauser_list)# 用户是否可用 bp.post("/user/active"…