1614. 括号的最大嵌套深度【 力扣(LeetCode) 】

文章目录

零、原题链接

1614. 括号的最大嵌套深度

一、题目描述

给定 有效括号字符串 s,返回 s 的 嵌套深度。嵌套深度是嵌套括号的 最大 数量。

二、测试用例

示例 1:

cpp 复制代码
输入:s = "(1+(2*3)+((8)/4))+1"

输出:3

解释:数字 8 在嵌套的 3 层括号中。

示例 2:

cpp 复制代码
输入:s = "(1)+((2))+(((3)))"

输出:3

解释:数字 3 在嵌套的 3 层括号中。

示例 3:

cpp 复制代码
输入:s = "()(())((()()))"

输出:3

提示:

cpp 复制代码
1 <= s.length <= 100
s 由数字 0-9 和字符 '+'、'-'、'*'、'/'、'('、')' 组成
题目数据保证括号字符串 s 是 有效的括号字符串

三、解题思路

  1. 基本思路:
      用栈进行匹配,每次压入栈更新最大值;
  2. 具体思路:
    • 遍历字符串
      • 如果是左括号,则压入栈,同时记录最大值
      • 如果是右括号,则出栈元素
      • 如果是其他字符,则跳过
    • 输出最大值。

四、参考代码

时间复杂度: O ( n ) \Omicron(n) O(n)

空间复杂度: O ( n ) \Omicron(n) O(n)

cpp 复制代码
class Solution {
public:
    int maxDepth(string s) {
        int n = s.length();
        int k = 0, _max = 0;

        for (int i = 0; i < n; i++) {
            if (s[i] == '(') {
                k++;
                _max = max(_max, k);
            } else if (s[i] == ')') {
                k--;
            }
        }

        return _max;
    }
};
相关推荐
iuu_star3 分钟前
C语言数据结构-顺序查找、折半查找
c语言·数据结构·算法
优雅的潮叭6 分钟前
c++ 学习笔记之 malloc
c++·笔记·学习
Yzzz-F10 分钟前
P1558 色板游戏 [线段树 + 二进制状态压缩 + 懒标记区间重置]
算法
漫随流水17 分钟前
leetcode算法(515.在每个树行中找最大值)
数据结构·算法·leetcode·二叉树
mit6.8241 小时前
dfs|前后缀分解
算法
扫地的小何尚1 小时前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
苦藤新鸡2 小时前
8.最长的无重复字符的子串
c++·力扣
千金裘换酒2 小时前
LeetCode反转链表
算法·leetcode·链表
꧁Q༒ོγ꧂3 小时前
C++ 入门完全指南(四)--函数与模块化编程
开发语言·c++
byzh_rc3 小时前
[认知计算] 专栏总结
线性代数·算法·matlab·信号处理