news 2026/6/13 14:00:23

算法---LeetCode 678. 有效的括号字符串

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法---LeetCode 678. 有效的括号字符串

1. 题目

原题链接

给你一个只包含三种字符的字符串,支持的字符类型分别是 ‘(’、‘)’ 和 ‘*’。请你检验这个字符串是否为有效字符串,如果是 有效 字符串返回 true 。

有效 字符串符合如下规则:

任何左括号 ‘(’ 必须有相应的右括号 ‘)’。
任何右括号 ‘)’ 必须有相应的左括号 ‘(’ 。
左括号 ‘(’ 必须在对应的右括号之前 ‘)’。
‘*’ 可以被视为单个右括号 ‘)’ ,或单个左括号 ‘(’ ,或一个空字符串 “”。

示例 1:

输入:s = “()”
输出:true
示例 2:

输入:s = “(*)”
输出:true
示例 3:

输入:s = “(*))”
输出:true

提示:

1 <= s.length <= 100
s[i] 为 ‘(’、‘)’ 或 ‘*’

2. 题解

2.1 解法1: 两个栈

两个栈记录目前为止不能匹配的字符,也就是*和(,每次出现右括号我们就应该去两个栈匹配可以匹配的左括号。

而*可以作为任何括号,也可以作为空字符串,所以我们应该优先用左括号匹配,所以我们出栈的策略如下:

  1. 遇到左括号,直接进栈,记录括号的位置。
  2. 遇到星号,直接进栈,记录星号的位置。
  3. 遇到右括号:
    a: 左括号栈里有元素,直接出栈。
    b: 左括号栈里无元素,*栈里有元素,直接出栈。无元素的话就已经匹配失败了。

如果遍历完数组的话,我们可能会发现左括号栈里还有结余元素。如果是20题的情况,已经失败了。但现在我们可能还有一些星号可以作为右括号用,所以我们进行下面的匹配操作:

对左括号栈逐一出栈,然后去看此时星号栈的栈顶,如果栈顶元素的位置大于左括号栈顶元素的位置,说明星号在括号的右侧,可以匹配。否则不可。

classSolution{publicbooleancheckValidString(Strings){Deque<Integer>star=newLinkedList<>();Deque<Integer>left=newLinkedList<>();for(inti=0;i<s.length();i++){charc=s.charAt(i);if(c=='('){left.offerLast(i);}elseif(c=='*'){star.offerLast(i);}elseif(!left.isEmpty()){left.pollLast();}elseif(!star.isEmpty()){star.pollLast();}else{returnfalse;}}while(!left.isEmpty()&&!star.isEmpty()){if(left.pollLast()>star.pollLast()){returnfalse;}}returnleft.isEmpty();}}

参考:
【微扰理论】肯定是栈呀)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 8:32:16

Kotaemon能否用于招聘JD解析?人才匹配初步尝试

Kotaemon能否用于招聘JD解析&#xff1f;人才匹配初步尝试 在当今企业招聘竞争日益激烈的环境下&#xff0c;HR每天面对成百上千份岗位描述&#xff08;Job Description&#xff0c;简称JD&#xff09;和候选人简历&#xff0c;如何快速、准确地完成信息提取与人岗匹配&#xf…

作者头像 李华
网站建设 2026/6/13 6:50:45

模组的导程与刚性

GTH 系列TOYO东佑达导程&#xff1a;该系列是东佑达核心轨道内嵌式模组&#xff0c;导程规格丰富。其中 GTH4 型号有 2/6/12mm 可选&#xff1b;GTH5 型号提供 2/5/10/20mm 多种选择&#xff0c;不同导程对应不同运行速度&#xff0c;比如 GTH4 配 2mm 导程时最高速度 100mm/s&…

作者头像 李华
网站建设 2026/6/9 23:23:50

六足机器人技术路线分析与行业应用教程

六足机器人技术路线分析与行业应用教程一、技术路线优劣势对比液压驱动路线优势&#xff1a;输出扭矩大&#xff08;可达$500\text{N}\cdot\text{m}$&#xff09;&#xff0c;动态响应快劣势&#xff1a;系统复杂度高&#xff0c;能耗达$3\text{kW}$&#xff0c;维护成本高代表…

作者头像 李华
网站建设 2026/6/10 14:11:45

Kotaemon能否生成Docker Compose?容器编排简化

Kotaemon与Docker Compose的集成潜力&#xff1a;构建可复用的AI系统部署范式 在企业级AI应用落地的过程中&#xff0c;一个常被忽视但至关重要的环节是——如何让开发环境中的智能对话系统&#xff0c;在生产环境中依然“能跑、快跑、稳跑”。这不仅是模型精度的问题&#xff…

作者头像 李华
网站建设 2026/6/11 20:18:47

Kotaemon蓝绿部署实战:零停机升级问答系统

Kotaemon蓝绿部署实战&#xff1a;零停机升级问答系统 在金融客服热线中&#xff0c;一次3分钟的系统停机可能意味着上千笔订单流失&#xff1b;在医疗智能导诊场景下&#xff0c;哪怕短暂的服务中断也可能影响患者体验。而今天的企业已无法容忍“我们正在维护”的提示页面——…

作者头像 李华