leetcode最长有效括号

. - 力扣(LeetCode)

32. 最长有效括号

困难

相关标签

相关企业

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

子串

的长度。

示例 1:

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

示例 2:

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

示例 3:

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

提示:

  • 0 <= s.length <= 3 * 104
  • s[i]'('')'
cpp 复制代码
class Solution {
public:
    int longestValidParentheses(string s) {
        stack<char> str;
        int max_len = 0;
        for (int i = 0; i < s.length(); i++) {
            if (s[i] == '(') {
                if (str.size() > 0 && str.top() == '(') {
                    continue;
                }
                str.push(s[i]);
            } else if (str.size() > 0) {
                char val = str.top();
                if (val == '(') {
                    str.push(s[i]);
                    max_len = std::max(max_len, (int)str.size());
                }
            }
        }
        return max_len;
    }
};
相关推荐
123过去7 小时前
wifi-honey使用教程
linux·网络·测试工具
lvxiangyu119 小时前
MPPI 算法证明重构:基于无穷维泛函变分与 KL 散度的构造性推导
算法·重构·最优控制·随机最优控制
2301_818419019 小时前
C++中的解释器模式变体
开发语言·c++·算法
爱学习的大牛1239 小时前
windows tcpview 类似功能 c++
c++
ab1515179 小时前
3.25完成*23、*24、*28、*30、*33、*38、*39、*40
算法
Deitymoon9 小时前
linux——孤儿进程和僵尸进程
linux
颜酱9 小时前
回溯算法实战练习(3)
javascript·后端·算法
biter down9 小时前
C++11 统一列表初始化+std::initializer_list
开发语言·c++
ShineWinsu10 小时前
爬虫对抗:ZLibrary反爬机制实战分析技术文章大纲
c++
小王不爱笑13210 小时前
G1 GC 的核心基础:Region 模型的补充细节
java·jvm·算法