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;
    }
};
相关推荐
cheems952710 小时前
[数据结构]栈和队列的互相模拟实现
数据结构·算法
cui_ruicheng10 小时前
C++11新特性(中):右值引用与移动语义
开发语言·c++·c++11
计算机安禾10 小时前
【数据结构与算法】第6篇:线性表(二):单链表的实现(头插法、尾插法)
c语言·数据结构·学习·算法·链表·visual studio code·visual studio
2401_8732046510 小时前
C++与Node.js集成
开发语言·c++·算法
文人sec10 小时前
【Linux 服务器上搭建 JMeter 性能测试与监控环境(实战版)】
linux·运维·服务器·jmeter·性能测试
☆56610 小时前
基于C++的区块链实现
开发语言·c++·算法
papaofdoudou10 小时前
Linux内核的边界在哪里?
linux·运维·服务器
liu****10 小时前
5.git标签管理
c++·git·版本控制
zzzsde10 小时前
【Linux】文件:基础IO
linux·运维·服务器
ysa05103010 小时前
迷宫传送[最短路径]
c++·笔记·算法·深度优先