【刷题17】最小栈、栈的压入弹出、逆波兰表达式

目录

一、最小栈

题目:

思路:

  • 定义两个栈,一个表示普通的栈st,另一个表示最小栈minst
  • push:入栈st;如果minst为空或者要进入的数据小于等于minst的栈顶元素,就入栈
  • pop:出栈st;如果st的栈顶元素等于minst的栈顶元素,minst就出栈。注意顺序,先用st的栈顶元素进行比较,不管比较是否进入判断条件,再st.pop
  • 返回st的栈顶元素;返回minst的栈顶元素

代码:

cpp 复制代码
class MinStack {
public:
    /** initialize your data structure here. */
    MinStack() {
        
    }
    
    void push(int x) {
        st.push(x);
        if(minst.empty() || x <= minst.top())
            minst.push(x);
    }
    
    void pop() {
        // 先比较,再删除
        if(st.top() == minst.top())
            minst.pop();
        st.pop();// 是栈顶的,注意顺序
    }
    
    int top() {
        return st.top();
    }
    
    int getMin() {
        return minst.top();
    }
    stack<int> st, minst;
};

二、栈的压入弹出

题目:

思路:栈

  • 循环,入栈序列全部入栈结束
  • 入栈序列进栈,下标++
  • 循环,栈不为空的情况下,栈顶元素与出栈序列比较,相等,下标++,并且栈pop;否则不进入循环
  • 最后出栈序列的下标等于出栈序列的个数,说明全部匹配,返回true;否则返回false

代码:

cpp 复制代码
 bool IsPopOrder(vector<int>& pushV, vector<int>& popV) {
     stack<int> st;
     int i = 0, j = 0;
     
     while(i < pushV.size())
     {
         st.push(pushV[i++]);
             
         while(!st.empty() && st.top() == popV[j])
         {
             st.pop();
             j++;
         }
     }
     if(j == popV.size()) return true;
     else return false;
 }

三、逆波兰表达式求值

题目:

思路:栈

  • 因为题目已经给了后缀表达式,所以可以使用
  • 是操作数,入栈
  • 是操作符,取出栈顶的两个元素,完成该操作符的运算,再放入栈
  • 最后返回栈顶元素就是结果

代码:

cpp 复制代码
class Solution {
public:
    int evalRPN(vector<string>& tokens) {
        stack<int> st;
        for(auto &e : tokens)
        {
            if(e == "+" || e == "-" || e == "*" || e == "/")
            {
                int right = st.top();
                st.pop();
                int left = st.top();
                st.pop();

                switch(e[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(e));
            }
        }
        return st.top();
    }
};
相关推荐
Altair澳汰尔几秒前
数据分析和AI丨知识图谱,AI革命中数据集成和模型构建的关键推动者
人工智能·算法·机器学习·数据分析·知识图谱
TT哇4 分钟前
【数据结构练习题】链表与LinkedList
java·数据结构·链表
东风吹柳16 分钟前
观察者模式(sigslot in C++)
c++·观察者模式·信号槽·sigslot
嵌入式科普22 分钟前
十一、从0开始卷出一个新项目之瑞萨RA6M5串口DTC接收不定长
c语言·stm32·cubeide·e2studio·ra6m5·dma接收不定长
A懿轩A25 分钟前
C/C++ 数据结构与算法【栈和队列】 栈+队列详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·栈和队列
Python机器学习AI29 分钟前
分类模型的预测概率解读:3D概率分布可视化的直观呈现
算法·机器学习·分类
吕小明么1 小时前
OpenAI o3 “震撼” 发布后回归技术本身的审视与进一步思考
人工智能·深度学习·算法·aigc·agi
大胆飞猪2 小时前
C++9--前置++和后置++重载,const,日期类的实现(对前几篇知识点的应用)
c++
1 9 J2 小时前
数据结构 C/C++(实验五:图)
c语言·数据结构·c++·学习·算法
程序员shen1616112 小时前
抖音短视频saas矩阵源码系统开发所需掌握的技术
java·前端·数据库·python·算法