当前位置: 首页 > java >正文

刷leetcode hot100返航版--栈和队列5/24

感觉二叉树每一题一个花样可能是因为栈和队列基础没打好,所以选择直接转入栈和队列。

想摆烂,煎熬----5/24

1.有效的括号

20. 有效的括号 - 力扣(LeetCode)

初版代码,有很多问题吧,正确的思路应该是把{ / [ / (压入栈,然后依次去匹配右边的括号

class Solution {

public:

    bool isValid(string s) {

        //妙的一点是网栈里加匹配的那半个,而不是原来的半个[感觉不能]

        int size = s.size();

        stack<char>st;

        int i = 0;

        while(i!=size){

            if(!st.empty()){

                char first = st.top();

                // st.pop();

                if(first == s[i]){

                    st.pop();

                    i++;

                }else{

                    i++;

                }

                continue;//

            }

            // st.push(s[i]);//说好的放另一半

            if(s[i]=='('){

                st.push(')');

            }else if(s[i]=='{'){

                st.push('}');

            }else if(s[i]=='['){

                st.push(']');

            }

            i++;//

           

        }//]]]

        if(st.empty()){

            return true;

        }else{

            return false;

        }

       

    }

};

混乱版本:【p.s.为了减少混乱其实可以for(),这样起码i++不会出错】

class Solution {
public:bool isValid(string s) {//妙的一点是往栈里加匹配的那半个,而不是原来的半个[感觉不能]int size = s.size();stack<char>st;int i = 0;while(i!=size){if(s[i]=='('){st.push(')');}else if(s[i]=='{'){st.push('}');}else if(s[i]=='['){st.push(']');}else{//右括号if(!st.empty()){char first = st.top();if(first == s[i]){st.pop();i++;//忘记了continue;}}return false;}i++;      }//]]]if(st.empty()){return true;}else{return false;}}
};

2.最小栈5/24

本题的目标就是把求栈的min值从O(n)优化为O(1)

155. 最小栈 - 力扣(LeetCode)

没思路

也是因为对C++类的不熟悉

class 类名 {

        private: // 私有成员,只能被类内的成员函数访问 数据类型 成员变量;

        public: // 公有成员,可以被类外部的代码访问

        返回类型 成员函数(); // 成员函数声明

}; // 注意这里有分号

两个栈,一个放当前min数,

用一个栈存储min,空间换时间 

class MinStack {//本题的目标就是用两个栈实现获得栈中元素min:O(n)变为O(1)
public:stack<int> st;stack<int>min;MinStack() {//常数时间内检索到最小元素的栈。// min.push(1e9);}void push(int val) {st.push(val);if(min.empty() ||val < min.top()){min.push(val);}else{min.push(min.top());}}void pop() {//st.pop();min.pop();}int top() {return st.top();        }int getMin() {return min.top();}
};/*** Your MinStack object will be instantiated and called as such:* MinStack* obj = new MinStack();* obj->push(val);* obj->pop();* int param_3 = obj->top();* int param_4 = obj->getMin();*/

 3.字符串解码

394. 字符串解码 - 力扣(LeetCode)

乱了,感觉一个左括号需要一个stack

很难区分[[ ]]和 [ ][ ]

但是其实就是满足栈的情况,

3[a2[c]]:3a先压入栈,然后2c压入栈,然后弹出

3[a]2[c]:3a先压入栈弹出,2c压入栈弹出

迷惑:如何处理当前重复的和之前压入栈的

#include <stack>
#include <string>
using namespace std;class Solution {
public:string decodeString(string s) {stack<int> numStack;    // 存储重复次数stack<string> strStack; // 存储外层字符串上下文int currentNum = 0;string currentStr = "";for (char c : s) {if (isdigit(c)) {currentNum = currentNum * 10 + (c - '0');} else if (c == '[') {// 压入当前状态并重置numStack.push(currentNum);strStack.push(currentStr);currentNum = 0;currentStr = "";} else if (c == ']') {// 弹栈并生成重复字符串int repeat = numStack.top();numStack.pop();string outerStr = strStack.top();strStack.pop();string temp;for (int i = 0; i < repeat; ++i) {temp += currentStr;}currentStr = outerStr + temp; // 栈顶+当前要重复的==总要重复的} else {currentStr += c;}}return currentStr; // 最终结果在此}
};

http://www.xdnf.cn/news/8795.html

相关文章:

  • java多态的学习笔记
  • 从工程实践角度分析H.264与H.265的技术差异
  • icexmoon-tree
  • C语言中的寄存器:理解与应用
  • c/c++的opencv椒盐噪声
  • 【python实战】二手房房价数据分析与预测
  • 日期组合统计
  • 基于MATLAB编程针对NCV检测数据去漂移任务的完整解决方案
  • Java中关于数组的使用(下)
  • NXP应用随记(九):M7内核的Hardfault相关认知
  • PTA刷题笔记(纠细节 有详解)
  • 力扣 74.搜索二维矩阵
  • Vue.extend
  • 工业自动化通信完全指南:西门子/三菱PLC对接
  • 【数据集】30 m地表温度LST数据集
  • OpenHarmony外设驱动使用 (十五),USB
  • 【C++】unordered_map、unordered_set 的使用
  • Java EE 初阶——文件操作和IO
  • NX二次开发-Block UI篇
  • git checkout 通配符
  • C++ queue对象创建、queue赋值操作、queue入队、出队、获得队首、获得队尾操作、queue大小操作、代码练习
  • 【Bluedroid】蓝牙Hid Host get_protocol全流程源码解析
  • docker问题记录
  • 台系厂商SSD主控之争:Phison对决SMI
  • uni-app学习笔记十三-vue3中slot插槽的使用
  • 2025年开发者生存白皮书
  • 中断和信号详解
  • 前端课设Web2
  • MySQL中简单的操作
  • day36 python神经网络训练