码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 11.9 表达式求值


    11.9 表达式求值

    【问题描述】给出一个合法的表达式,请输出它的计算结果。表达式满足以下条件:
    ① 只有+、-、*、/、^(乘方)运算和括号。
    ② 所有操作数都是非负数。计算过程中(包括最后结果)可能会出现负数,但不会超过 int 的表示范围。
    ③ 表达式开头、结尾或表达式内部可能有多余的空格。

    (1) 模拟

    设两个栈,一个是操作数栈,用来存放操作数,如 3、4、8 等,另一个是运算符栈,用来存放运算符。
    首先,将“(”压进运算符栈的栈底①。然后,依次扫描,按照栈的后进先出原则进行:
    ① 遇到操作数,进操作数栈;
    ② 遇到运算符时,则需将此运算符的优先级与栈顶运算符的优先级比较。
    若高于栈顶元素则进栈,继续扫描下一符号。否则,将运算符栈的栈顶元素退栈,形成一个操作码 Q,同时操作数栈的栈顶元素两次退栈,形成两个操作数 a、b,让计算机对操作数与操作码完成一次运算操作,即 aQb,并将其运算结果存放在操作数栈中。
    注意:在向 calc 函数传入表达式之前,必须在表达式两端加一层小括号!

    1. #define Pop { pos--; \
    2. switch (symbol[pos+1]) { \
    3. case '+': number[pos]+=number[pos+1];break; \
    4. case '-': number[pos]-=number[pos+1];break; \
    5. case '*':
  • 相关阅读:
    TS流分析
    SetFitABSA: 基于 SetFit 的少样本、方面级情感分析
    【Oracle】[INS-30131]执行安装程序验证所需的初始设置失败。
    理解网络协议里的协议
    Spring Boot 项目中使用 JSP
    MongoDB——window11安装mongodb5.0.21版本服务端(图解版)
    Blazor WebAssembly 渐进式 Web 应用程序 (PWA) 离线处理数据
    uniapp-vue3-微信小程序-标签选择器wo-tag
    切分pdf并提取内容
    神经网络在控制中的应用,神经元网络控制的作用
  • 原文地址:https://blog.csdn.net/zhengheda/article/details/126676171
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号