• (C++栈与队列02) 栈的应用 单调队列


    150、逆波兰表达式求值

    建立一个栈,遍历逆波兰表达式,将数字压入栈中,如果是运算符,将栈前两项数字取出,进行对应的运算后,将结果压入栈中。

    1. class Solution {
    2. public:
    3. int evalRPN(vector& tokens) {
    4. stack<int> st;
    5. for(int i = 0; i < tokens.size(); i++) {
    6. if(tokens[i] == "+" || tokens[i] == "-" || tokens[i] == "*" || tokens[i] == "/") {
    7. int num1 = st.top();
    8. st.pop();
    9. int num2 = st.top();
    10. st.pop();
    11. int num3;
    12. if(tokens[i] == "+") num3 = num1 + num2;
    13. if(tokens[i] == "-") num3 = num2 - num1;
    14. if(tokens[i] == "*") num3 = num1 * num2;
    15. if(tokens[i] == "/") num3 = num2 / num1;
    16. st.push(num3);
    17. }else {
    18. st.push(stoi(tokens[i]));
    19. }
    20. }
    21. return st.top();
    22. }
    23. };

    时间复杂度:O(n)

    空间复杂度:O(n)

    239、滑动窗口最大值

    第一次接触到单调队列,消化消化

    1. class Solution {
    2. public:
    3. vector<int> maxSlidingWindow(vector<int>& nums, int k) {
    4. MyQueue que;
    5. vector<int> result;
    6. for(int i = 0; i < k; i++) {
    7. que.push(nums[i]);
    8. }
    9. result.push_back(que.front());
    10. for(int i = k; i < nums.size(); i++) {
    11. que.pop(nums[i - k]);
    12. que.push(nums[i]);
    13. result.push_back(que.front());
    14. }
    15. return result;
    16. }
    17. private:
    18. class MyQueue {
    19. public:
    20. deque<int> que;
    21. void pop(int value) {
    22. if(!que.empty() && value == que.front()) {
    23. que.pop_front();
    24. }
    25. }
    26. void push(int value) {
    27. while(!que.empty() && value > que.back()) {
    28. que.pop_back();
    29. }
    30. que.push_back(value);
    31. }
    32. int front() {
    33. return que.front();
    34. }
    35. };
    36. };

    时间复杂度:O(n)

    空间复杂度:O(k)

  • 相关阅读:
    python类
    【英语语法】but
    USB2.0 UTMI+接口
    DNS 解析流程
    巧用OpenSSH进行域内权限维持
    云原生面试
    Python进阶学习(3)绑定方法
    f-string 格式化字符串的用法
    面试突击81:什么是跨域问题?如何解决?
    74cms骑士人才招聘系统源码SE版 v3.16.0
  • 原文地址:https://blog.csdn.net/qq_44962949/article/details/140407374