栈|逆波兰表达式求值

这篇具有很好参考价值的文章主要介绍了栈|逆波兰表达式求值。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目

逆波兰表达式求值
栈|逆波兰表达式求值,算法
逆波兰表达式就是后缀表达式,我们平时写的带括号的是中缀表达式。区分中缀表达式和后缀表达式 就是 操作数 和 操作符 的先后关系。 操作符在后 就是后缀表达式

  • 后缀表达式 的用途就是 让计算机直到计算的先后顺序!
    比如 我们中缀表达式 a * (b - c) 以我们人类的智慧一眼就知道先算后面的括号,是跳跃式的。但是计算机是从左到右扫描整个表达式。所以我们就需要把这个表达式改为其他形式。
  • a* (b - c)改成后缀表达式就是 a bc - * 后面的操作符 是根据优先级排的,()的优先级最高
  • 再来个例子 a + b * c - d 改成后缀表达式就是 a bc*+d-

算法原理

  • 先定义一个stack ,遍历数组,遇到数字就入栈
  • 遇到操作符就出栈,先出的为右操作数,后出的为左操作数,然后计算的结果再入栈。
  • 最后返回栈顶元素就ok了

栈|逆波兰表达式求值,算法栈|逆波兰表达式求值,算法
栈|逆波兰表达式求值,算法
栈|逆波兰表达式求值,算法

代码实现

int evalRPN(vector<string>& tokens) {
    set<string> s = { "+","-","*","/" };
    stack<int> st;
    for (auto& str : tokens) {
        if (s.find(str) != s.end()) {
            int right = st.top();
            st.pop();
            int left = st.top();
            st.pop();
            switch (str[0]) {
            case '+':
                st.push(left + right);
                break;
            case '-':
                st.push(left - right);
                break;
            case '*':
                st.push(left * right);
                break;
            case '/':
                st.push(left / right);
                break;
            }
        }
        else {
            st.push(stoi(str));
        }
    }
    return st.top();
}

可能有同学好奇字符怎么转整型的

补充 stoi的实现

stoi的实现文章来源地址https://www.toymoban.com/news/detail-847693.html

class Solution {
public:
    int myAtoi(string str) {
        int i = 0;
        while(str[i] == ' '){
            i++;
        }
        int flag = 1;
        switch (str[i]){
            case  '-':
                flag = -1;
                i++;
                break;
            case  '+':
                flag = 1;
                i++;
                break;
        }
        //i++;
        long long ret = 0;
        for(; i < str.size(); i++){
            if(str[i]>'9' || str[i]<'0'){
                break;
            }
            ret = 10* ret + (str[i] -'0') ;
            if(ret > INT_MAX){
                break;
            }
        }
        ret *= flag;
        if(ret > INT_MAX){
            ret = INT_MAX ;
        }
        if(ret < INT_MIN){
            ret = INT_MIN;
        }
        return ret ;
    }
};

到了这里,关于栈|逆波兰表达式求值的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JAVA练习99-逆波兰表达式求值

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、题目-逆波兰表达式求值 1.题目描述 2.思路与代码 2.1 思路 2.2 代码 总结 提示:这里可以添加本文要记录的大概内容: 4月5日练习内容 提示:以下是本篇文章正文内容,下面案例可供参考

    2023年04月08日
    浏览(34)
  • 算法训练day11Leetcode20有效的括号1047删除字符串中所有相邻重复项150逆波兰表达式求值

    https://leetcode.cn/problems/valid-parentheses/description/ https://programmercarl.com/0020.%E6%9C%89%E6%95%88%E7%9A%84%E6%8B%AC%E5%8F%B7.html 判断右括号后忘记pop 括号匹配是使用栈解决的经典问题。 如果还记得编译原理的话,编译器在 词法分析的过程中处理括号、花括号等这个符号的逻辑,也是使用了栈

    2024年01月17日
    浏览(50)
  • 【数据结构】你知道波兰表达式和逆波兰表达式吗?我才知道原来栈在表达式求值中还能这样使用……

    大家好,很高兴又和大家见面啦!!! 在前面的内容中我们详细介绍了栈的第一种应用——在括号匹配问题中的应用,如果还没有阅读过的朋友可以回看前面两篇文章。在今天的内容中我们将介绍栈的另一种应用——在表达式求值中的应用。 表达式相信大家应该不陌生了,

    2024年04月27日
    浏览(27)
  • 力扣:150. 逆波兰表达式求值(Python3)

    给你一个字符串数组  tokens  ,表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 注意: 有效的算符为  \\\'+\\\' 、 \\\'-\\\' 、 \\\'*\\\'  和  \\\'/\\\'  。 每个操作数(运算对象)都可以是一个整数或者另一个表达式。 两个整数之间的除法总

    2024年02月05日
    浏览(39)
  • 【代码随想录-Leetcode第四题:150. 逆波兰表达式求值】

    给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 注意: 有效的算符为 ‘+’、‘-’、‘*’ 和 ‘/’ 。 每个操作数(运算对象)都可以是一个整数或者另一个表达式。 两个整数之间的除法总

    2024年02月13日
    浏览(31)
  • (栈和队列) 150. 逆波兰表达式求值 ——【Leetcode每日一题】

    难度:中等 给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 注意 : 有效的算符为 ‘ + ’、‘ - ’、‘ * ’ 和 ‘ / ’ 。 每个操作数(运算对象)都可以是一个整数或者另一个表达式。 两个

    2024年02月08日
    浏览(28)
  • 栈的OJ题(逆波兰表达式求值+括号匹配+出入栈顺序匹配+最小栈)

    平时使用是算式是中缀表达式 逆波兰表达式是一种后缀表达式,算符写在后面。 优点: 1.去掉括号后表达式无歧义 2.适合用栈操作运算:遇到数字则入栈;遇到算符则取出栈顶两个数字进行计算,并将结果压入栈中 3.中缀转后缀:加上括号,将对应的运算符放在括号外 1.题

    2024年02月08日
    浏览(41)
  • 【数据结构练习题】栈——1.括号匹配 2.逆波兰表达式求值 3.出栈入栈次序匹配 4.最小栈

    ♥♥♥♥♥个人主页♥♥♥♥♥ ♥♥♥♥♥数据结构练习题总结专栏♥♥♥♥♥ 在学习数据结构的过程中遇到了各种各样类型的题目,我在解答这些题目的时候收获了不少,所以我想开设一个专栏来分享我平时做题的收获,在我分享的题中我采用三步法来阐述,希望大家可

    2024年04月09日
    浏览(47)
  • 代码随想录复习 1047. 删除字符串中的所有相邻重复项 150 逆波兰表达式求值 239 滑动窗口最大值

    1047. 删除字符串中的所有相邻重复项 代码如下  func removeDuplicates(s string) string {             var  stack []byte   //结果栈数组             for i := 0 ; i  len(s) ; i++ {                 if len(stack)  0  stack[len(stack)-1] == s[i] {  //如果当前遍历到的元素

    2024年02月05日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包