【数据结构-合法括号字符串】【hard】【拼多多面试题】力扣32. 最长有效括号

news/2024/11/8 23:57:17 标签: 数据结构, leetcode

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

示例 1:
输入:s = “(()”
输出:2
解释:最长有效括号子串是 “()”

示例 2:
输入:s = “)()())”
输出:4
解释:最长有效括号子串是 “()()”

示例 3:
输入:s = “”
输出:0

在这里插入图片描述

class Solution {
public:
    int longestValidParentheses(string s) {
        stack<int> st;
        st.push(-1);
        int maxNum = 0;
        for(int i = 0; i < s.size(); i++){
            char c = s[i];
            if(c == '('){
                st.push(i);
            }
            else{
                st.pop();
                if(st.empty()){
                    st.push(i);
                }
                else{
                    maxNum = max(maxNum, i - st.top());
                }
            }
        }
        return maxNum;
    }
};

时间复杂度: O(n),n 是给定字符串的长度。我们只需要遍历字符串一次即可。
空间复杂度: O(n)。栈的大小在最坏情况下会达到 n,因此空间复杂度为 O(n) 。

首先为什么我们要向栈中推入一个-1,实际上这代表着从字符串第0个字符开始计数,然后当发现右括号找不到左括号,也就是栈st为空的时候,就将右括号坐标i填入到栈中,代表着从第i+1个元素开始计数。每当右括号找到匹配的左括号的时候,我们就记录该计数 maxNum = max(maxNum, i - st.top());并与最大计数进行比较,看当前计数是否可以构成最长有效括号。


http://www.niftyadmin.cn/n/5744589.html

相关文章

测试自动化如何和业务流程结合?

测试自动化框架固然重要&#xff0c;但是最终自动化的目的都是为了业务服务的。 那测试自动化如何对业务流程产生积极影响&#xff1f; 业务流程的重要性 测试自动化项目并非孤立存在&#xff0c;其生命周期与被测试的应用程序紧密相关。项目的价值在于被整个开发团队所使用&a…

Prometheus 不是 OPEN TSDB

误解——这无疑是阐释我早期 Prometheus 体验的恰当词汇。彼时&#xff0c;我怀揣着丰富的 Graphite 使用经验以及中等程度的 InfluxDB 经验&#xff0c;开始接触 Prometheus。 在我眼中&#xff0c;Graphite 是一个性能卓越却有着相当局限性的系统。在 Graphite 里&#xff0c…

新系统如何进行模型环境配置

在机器学习和深度学习中&#xff0c;一个良好的开发环境能够显著提高工作效率。本篇博客将详细介绍如何在新的Linux系统&#xff08;以Ubuntu为例&#xff09;上进行模型环境的配置&#xff0c;包括基础系统设置、Python虚拟环境搭建、常用库的安装以及GPU驱动和CUDA的安装等。…

C++【string类,模拟实现string类】

&#x1f31f;个人主页&#xff1a;落叶 &#x1f31f;当前专栏: C专栏 目录 为什么学习string类 C语言中的字符串 标准库中的string类 auto和范围for auto关键字 迭代器 范围for string类的常用接口说明和使用 1. string类对象的常见构造 2.string类对象的容量操作 3…

laravel chunkById 分块查询 使用时的问题

laravel chunkById 分块查询 使用时容易出现的问题 1. SQLSTATE[23000]: Integrity constraint violation: 1052 Column ‘id’ in where clause is ambiguous 使用chunkById时&#xff0c;单表进行分块查询&#xff0c;是不会出现id重复的&#xff0c;当用两个表进行 join 查…

netstat中sendq/recvq用于排查发送端发送数据的问题

web同事开发了一个用于接收syslog数据的服务器&#xff0c;不清楚web的开发方式&#xff0c;用来联调的发送端是我们的C模块 反馈syslog udp形式接收正常&#xff0c;速度正常&#xff0c;数量也正常&#xff0c;syslog tcp形式接收开始比较快后面越来越慢&#xff0c;并且知道…

内部知识库:优化企业培训流程的关键驱动力

在当今快速变化的商业环境中&#xff0c;企业培训的重要性日益凸显。内部知识库作为整合、管理和分享企业内部学习资源的关键工具&#xff0c;正逐步成为优化企业培训流程的核心。以下将探讨内部知识库如何通过多种功能&#xff0c;助力企业提升培训效率、质量和员工满意度。 …

sheng的学习笔记-tidb框架原理

目录 TiDB整体架构 TiDB架构图 组件-TiDB Server 架构图 流程 关系型数据转成kv ​编辑 组件-TiKV Server​ 架构图 主要功能&#xff1a; 列簇 组件-列存储TiFlash 组件-分布式协调层&#xff1a;PD PD架构图 路由 Region Cache back off TSO分配 概念 解…