HOT90-最长有效括号

leetcode原题链接最长有效括号

题目描述

给你一个只包含 '('')' 的字符串,找出最长有效(格式正确且连续)括号子串的长度。

示例 1:

复制代码
输入:s = "(()"
输出:2
解释:最长有效括号子串是 "()"

示例 2:

复制代码
输入:s = ")()())"
输出:4
解释:最长有效括号子串是 "()()"

示例 3:

复制代码
输入:s = ""
输出:0

提示:

  • 0 <= s.length <= 3 * 104
  • s[i]'('')'

解题方法:栈。采用栈保存字符和对应的下标<char, int>。然后遍历字符串:

  1. 遇到左括号(,直接将字符入栈。

  2. 遇到右括号,先判断栈是否为空,如果栈为空,则直接将右括号和对应的下标压入栈;如果栈非空,且栈顶元素为左括号对应的pair,则先弹出匹配的左括号,并利用对应的下标更新当前的匹配最大长度。

C++代码

cpp 复制代码
#include <iostream>
#include <stack>
#include <string>

class Solution {
public:
    int longestValidParentheses(string s) {
        int n = s.size();
        std::stack<std::pair<char, int>> st;
        st.push({')', -1});//入栈的右括号永远不会弹出栈
        int max_len = 0;
        for (int i = 0; i < n; i++) {
            if (s[i] == '(') {
                st.push({'(', i});
            } else { //每遇到一次右括号')',弹出对应的左括号(后,都需要计算一次max_len
                std::pair<char, int> top_value = st.top();
                if (top_value.first == '(') { //找到匹配的括号,先弹出,再计算max_len
                    st.pop(); //先弹出匹配的左括号,再计算当前的匹配最大长度
                    max_len = std::max(max_len, i - st.top().second);// )()
                } else {
                    st.push({')', i});
                }
            }
        }
        return max_len;
    }
};
相关推荐
小江的记录本1 小时前
【分布式】分布式核心组件——分布式ID生成:雪花算法、号段模式、美团Leaf、百度UidGenerator、时钟回拨解决方案
分布式·后端·算法·缓存·性能优化·架构·系统架构
大江东去浪淘尽千古风流人物2 小时前
【cuVSLAM】GPU 加速、多相机、实时视觉/视觉惯性 SLAM设计优势
c++·人工智能·数码相机·ubuntu·计算机视觉·augmented reality
励志的小陈8 小时前
数据结构--二叉树知识讲解
数据结构
自信150413057598 小时前
重生之从0开始学习c++之模板初级
c++·学习
leobertlan8 小时前
好玩系列:用20元实现快乐保存器
android·人工智能·算法
青梅橘子皮8 小时前
C语言---指针的应用以及一些面试题
c语言·开发语言·算法
笨笨饿8 小时前
#58_万能函数的构造方法:ReLU函数
数据结构·人工智能·stm32·单片机·硬件工程·学习方法
历程里程碑9 小时前
2. Git版本回退全攻略:轻松掌握代码时光机
大数据·c++·git·elasticsearch·搜索引擎·github·全文检索
极客智造9 小时前
深度解析 C++ 类继承与多态:面向对象编程的核心
c++
_深海凉_9 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode