leetcode 括号类型题解

参考宫水三叶题解,非常有启发意义https://leetcode.cn/problems/valid-parenthesis-string/solutions/992601/gong-shui-san-xie-yi-ti-shuang-jie-dong-801rq/

  1. 最长有效括号

使用栈+一次遍历,巧妙得出最长有效括号长度

复制代码
func longestValidParentheses(s string) int {
    stack := make([]int,0)
    stack =append(stack,-1)
    mx := 0 
    for i:=0;i<len(s);i++{
        if s[i]=='('{
            stack = append(stack,i)
        }else{
            stack = stack[:len(stack)-1]
            if len(stack) == 0 {
                stack =append(stack,i)
            }else{
                mx  =max(mx,i-stack[len(stack)-1])
            }
        }
    }

    return mx
}
相关推荐
子夜江寒13 小时前
YOLO目标检测算法简介
算法·yolo·目标检测
逆境不可逃13 小时前
LeetCode 热题 100 之 279. 完全平方数 322. 零钱兑换 139. 单词拆分 300. 最长递增子序列
java·算法·leetcode·职场和发展
美式请加冰13 小时前
位运算符的介绍和使用
数据结构·算法
tankeven13 小时前
HJ127 小红的双生串
c++·算法
Fcy64813 小时前
与链表有关的算法题
数据结构·算法·链表
KerwinChou_CN14 小时前
LangGraph 快速入门
服务器·网络·算法
安之若素.re14 小时前
918. 环形子数组的最大和
算法
阿阿阿阿里郎14 小时前
ROS2快速入门--C++基础
开发语言·c++·算法
free-elcmacom14 小时前
C++<x>new和delete
开发语言·c++·算法
lxh011314 小时前
计算右侧小于当前元素的个数 题解
javascript·数据结构·算法