稀碎从零算法笔记Day17-LeetCode:有效的括号

题型:栈

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

来源:LeetCode

题目描述(红字为笔者添加)

给定一个只包括 '('')''{''}''['']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

**正确情况: ( { [ ] } )**错误情况:( { )}

题目样例

示例 1:

复制代码
输入:s = "()"
输出:true

示例 2:

复制代码
输入:s = "()[]{}"
输出:true

示例 3:

复制代码
输入:s = "(]"
输出:false

提示:

  • 1 <= s.length <= 104
  • s 仅由括号 '()[]{}' 组成

题目思路

题目描述机翻,推荐看英语原文/笑

一开始没思路,看题解对于这种【对称型匹配】,适合用【栈】来匹配

具体思路就是:遍历字符串 ①如果遍历得到的 char 是【左括弧】------这里我们先不讨论是哪一种,那么就在栈中压入一个【对应的右括弧】。 ②如果遍历得到的char是【不是左括弧】,那么就从栈中弹出栈顶元素------ 前提是栈顶元素和 char 是同一种【右括弧】

C++代码

cpp 复制代码
class Solution {
public:
    bool isValid(string s) {
    //利用栈匹配括弧(栈适合做"对称匹配类")
    // 遍历字符串:碰到【左括弧】,往栈中压入【对应的右括弧】
    // 碰到【右括弧】,栈中弹出【对应的左括弧】
    int len=s.length();
    if(len%2 != 0)
        return 0;
    stack<char> stack_ch;
    for(int i=0;i<len;i++)
    {
        if(s[i] == '(') 
            {
                stack_ch.push(')');
                continue;
            }
        else if(s[i] == '{') 
            {
                stack_ch.push('}');
                continue;
            }
        else if(s[i] == '[') 
        {
            stack_ch.push(']');
            continue;
        }
        else if(stack_ch.empty() || s[i] != stack_ch.top())//表示栈中没有要匹配的括弧 
            return 0;
        else
            stack_ch.pop();//相等,说明市对应的【右括弧】
            
            
    }
    return stack_ch.empty();//最后如果栈为空,说明【左括弧】和【右括弧】想对应。不为空 说明有多余的【左括弧】
    }
};

结算页面

相关推荐
某林2121 小时前
基于SLAM Toolbox的移动机器人激光建图算法原理与工程实现
stm32·嵌入式硬件·算法·slam
修炼地1 小时前
代码随想录算法训练营第四十三天 | 图论理论基础、深搜理论基础、卡码网98. 所有可达路径、797. 所有可能的路径、广搜理论基础
算法·深度优先·图论
iAkuya1 小时前
(leetcode)力扣100 23反转链表(迭代||递归)
算法·leetcode·链表
剪一朵云爱着1 小时前
PAT 1095 Cars on Campus
算法·pat考试
MicroTech20252 小时前
激光点云快速配准算法创新突破,MLGO微算法科技发布革命性点云配准算法技术
人工智能·科技·算法
Cathy Bryant2 小时前
傅里叶变换(一):简介
笔记·算法·数学建模·信息与通信·傅里叶分析
allan bull3 小时前
在节日中寻找平衡:圣诞的欢乐与传统节日的温情
人工智能·学习·算法·职场和发展·生活·求职招聘·节日
wdfk_prog3 小时前
[Linux]学习笔记系列 -- [fs]fs-writeback
linux·笔记·学习
似水এ᭄往昔3 小时前
【C++】--封装红⿊树实现mymap和myset
开发语言·数据结构·c++·算法·stl
咕噜企业分发小米3 小时前
腾讯云向量数据库HNSW索引如何更新?
人工智能·算法·腾讯云