news 2026/5/26 9:45:33

算法---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/5/26 7:37:49

Kotaemon自动化流水线构建:CI/CD集成最佳实践

Kotaemon自动化流水线构建&#xff1a;CI/CD集成最佳实践 在企业级AI系统日益复杂的今天&#xff0c;一个智能客服从开发到上线的旅程&#xff0c;往往不是靠“跑通demo”就能结束的。真正的挑战在于&#xff1a;如何让每一次代码提交都安全、可控地走向生产环境&#xff1f;尤…

作者头像 李华
网站建设 2026/5/25 15:15:24

Kotaemon能否用于心理健康自助?资源推荐而非诊疗

Kotaemon能否用于心理健康自助&#xff1f;资源推荐而非诊疗 在焦虑情绪日益普遍、心理服务资源却严重不足的今天&#xff0c;一个现实问题摆在面前&#xff1a;如何让那些暂时无法接触到专业咨询的人&#xff0c;也能获得及时、可靠的心理支持&#xff1f; AI对话系统似乎提…

作者头像 李华
网站建设 2026/5/25 22:55:27

环境配置错误

在配置环境的时候&#xff0c;你会遇到千奇百怪的各种错误。沉静下来&#xff0c;耐心一个一个解决。多跟ai交互&#xff0c;把报错历程做成一个思维导图&#xff0c;防止自己迷路&#xff0c;因为极有可能在解决一个报错的过程中又报错&#xff0c;不断循环嵌套&#xff0c;就…

作者头像 李华
网站建设 2026/5/26 7:35:17

Java反射的作用与应用场景

Java反射&#xff08;Reflection&#xff09;是Java语言提供的一种强大机制&#xff0c;允许程序在运行时动态地检查、访问和修改类、对象、方法和属性&#xff0c;而无需在编译时知道这些信息。重要作用&#xff1a;1. 动态类型操作// 运行时加载类 Class<?> clazz Cl…

作者头像 李华
网站建设 2026/5/26 7:34:17

Kotaemon如何处理递归问题?层次化推理能力解析

Kotaemon如何处理递归问题&#xff1f;层次化推理能力解析 在构建企业级智能对话系统的过程中&#xff0c;一个长期存在的挑战是&#xff1a;如何让AI真正“理解”复杂问题&#xff0c;并像人类专家一样进行有条理的思考&#xff1f;尤其是在金融分析、法律咨询或医疗诊断这类…

作者头像 李华
网站建设 2026/5/26 0:23:44

Kotaemon能否用于快递物流查询?多源数据整合实践

Kotaemon能否用于快递物流查询&#xff1f;多源数据整合实践 在电商包裹每天以亿计流动的今天&#xff0c;用户早已不满足于“已发货”“运输中”这样的状态提示。他们更关心的是&#xff1a;“我的快递是不是被堵在路上了&#xff1f;”“为什么昨天显示到达北京&#xff0c;今…

作者头像 李华