当前位置: 首页 > news >正文

遍历s ,并用一个栈来表示括号的深度。

遍历s ,并用一个栈来表示括号的深度。

遇到 ‘(’ 则将字符入栈,遇到 ‘)’ 则将栈顶字符出栈。栈从空到下一次空的过程,则是扫描了一个原语的过程。一个原语中,首字符和尾字符应该舍去,其他字符需放入结果字符串中。因此,在遇到 ‘(’ 并将字符入栈后,如果栈的深度为 1 ,则不把字符放入结果;在遇到 ‘)’ 并将栈顶字符出栈后,如果栈为空,则不把字符放入结果。

其他情况下,需要把字符放入结果。代码对流程进行了部分优化,减少了判断语句。

代码

Python3

class Solution: def removeOuterParentheses(self, s: str) -> str: res, stack = "", [] for c in s: if c == ')': stack.pop() if stack: res += c if c == '(': stack.append(c) return res

C++

class Solution { public: string removeOuterParentheses(string s) { string res; stack<char> st; for (auto c : s) { if (c == ')') { st.pop(); } if (!st.empty()) { res.push_back(c); } if (c == '(') { st.emplace(c); } } return res; } };

Java

class Solution { public String removeOuterParentheses(String s) { StringBuffer res = new StringBuffer(); Deque<Character> stack = new ArrayDeque<Character>(); for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); if (c == ')') { stack.pop(); } if (!stack.isEmpty()) { res.append(c); } if (c == '(') { stack.push(c); } } return res.toString(); } }

复杂度分析

时间复杂度:O(n),其中 n 是输入 s 的长度。仅需遍历 s 一次。
空间复杂度:O(n),其中 n 是输入 s 的长度。需要使用栈,长度最大为 O(n)。

http://www.zskr.cn/news/1430505.html

相关文章:

  • LangChain4j 如何实现 RAG(检索增强生成)?请简述完整流程及其核心组件。
  • 【AI工具版权避坑指南】:20年法律+技术双背景专家亲授3大高危场景与5步合规自查法
  • 2026论文爆款降AI率软件大曝光:一键抹平AI痕迹稳过知网! - 降AI小能手
  • 上海家庭教育指导师正规报名入口:中山优才教育 - 当下教育培训干货
  • AI初创公司如何避免盲目行动:从技术驱动到市场验证的生存指南
  • 基于小程序的酒店客房管理系统毕业设计
  • 搞定SAP SMARTFORMS表格布局:手把手教你调整列宽、行高和解决‘画布溢出’报错
  • 保姆级教程:在Ubuntu 22.04 LTS上搞定TPM2-Tools安装与基础命令测试
  • 你的测试覆盖够了吗?手把手用VectorCAST/QA分析C++项目覆盖率,生成老板爱看的Dashboard报告
  • A9G模块通过AT指令实现MQTT订阅:从网络配置到消息接收全流程详解
  • 别再只用yum了!CentOS 7/8上两种安装Node.js 16.x的保姆级对比(含环境变量配置)
  • 从Kettle 8.2升级到9.3踩的坑:官网下载和Hadoop Shims依赖问题全记录
  • 九大网盘直链下载高效解决方案:LinkSwift智能下载助手完全指南
  • VoiceFixer语音修复工具:3分钟让任何模糊录音变清晰的完整指南
  • 别再只盯着BOLA的公式了!聊聊ABR算法里那些比‘最优解’更重要的工程权衡
  • 从SourceForge到Hitachi Vantara:Kettle下载地址变迁背后的故事与Linux环境搭建实战
  • 2026年5月成都春熙路附近好吃的火锅串串推荐榜|本地人实测口碑评分4.5分+ - TOP10品牌推荐榜单
  • 考研各科真题答题卡PDF可打印(英语、管综、数学等)
  • 保姆级教程:用ONNX Runtime在Python中直接运行DETR目标检测模型(附完整代码)
  • 2026 年 ZJIT 引入新寄存器分配器:全局分配优势大,方法内联正推进!
  • 从零信任到实战响应:构建现代网络安全防御体系的完整指南
  • DIY远程控制工程移动电源:18650电池组与射频遥控集成方案
  • ChatGPT内容创作实战:30个故事生成实验揭示AI协作潜力与陷阱
  • 2026论文降AI率网站:11款工具实测谁在“降重”谁在“划水”? - 降AI小能手
  • 告别寄存器:用STM32CubeMX的FSMC模块轻松搞定TFT LCD屏幕驱动(STM32F103实战)
  • 如何在Windows 11上免费安装安卓子系统:完整指南与实用技巧
  • Nerf枪电路改造实战:从飞轮电机驱动到LED联动灯光系统
  • 手把手教你用MounRiver Studio给CH32V307驱动4P OLED屏(附完整工程下载)
  • INCA工程维护实战:当A2L文件升级后,如何快速更新工程并保证标定数据不丢失?
  • 深入UEFI内存管理:图解HOB List的构建与Resource Descriptor HOB的奥秘