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

刷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; // 最终结果在此}
};

相关文章:

  • 人工智能数学基础实验(三):最小二乘法-数值计算
  • 以下是修改Java版《我的世界》字体的分步指南(DeepSeek)
  • 后经济时代开源链动2+1模式AI智能名片S2B2C商城小程序驱动零售企业转型研究
  • 基于Spring Boot的高校科研绩效管理的设计与实现
  • Java线程同步:从多线程协作到银行账户安全
  • Linux核心技术:Linux文件系统与bootFS/rootFS
  • 进程通信-内存共享
  • 【目标检测】【医学图像目标检测】BGF-YOLO:脑肿瘤检测的多尺度注意力特征融合
  • Flink 常用算子详解与最佳实践
  • Python数据可视化实战:让数据从「数字堆」变成「故事书」
  • NestJS——重构日志、数据库、配置
  • Javase 基础加强 —— 08 IO流
  • 【Python 命名元祖】collections.namedtuple 学习指南
  • Java中关于数组的使用(下)
  • springboot中过滤器配置使用
  • 《爱的艺术》
  • python打卡训练营打卡记录day36
  • 电梯调度算法详解与Python实现
  • 简单数学板子和例题
  • 【短距离通信】【WiFi】WiFi7关键技术之4096-QAM、MRU
  • 企业网站建设方案平台/自动seo优化
  • 网上做游戏赚钱的网站有哪些/对百度竞价排名的看法
  • 做网站的财务需求/网站推广优化
  • 网站建设及系统开发/网络优化大师手机版
  • 网站聚合搜索怎么做/厦门seo起梦网络科技
  • 邦邻营销型网站建设/seo上海优化