LeetCode 678——有效的括号字符串

阅读目录

    • [1. 题目](#1. 题目)
    • [2. 解题思路](#2. 解题思路)
    • [3. 代码实现](#3. 代码实现)

1. 题目

2. 解题思路

需要两个栈,一个用来保存左括号所在的位置索引,一个用来保存星号所在的位置索引。

从左往右遍历字符串,如果是左括号或者星号,则将位置索引分别入栈,如果遇到右括号,首先用左括号栈中的左括号进行匹配,没有左括号则使用星号作为左括号来进行匹配,如果二者都为空,匹配失败

右括号匹配完后,如果还有余下的左括号没有匹配完,那么就需要在左括号右边的星号来作为右括号进行匹配

最终,左括号也匹配完,那么字符串有效,因为余下的星号可以作为空字符串。

时间复杂度为 O ( n ) O(n) O(n),空间复杂度也为 O ( n ) O(n) O(n)。

3. 代码实现

c 复制代码
class Solution {
public:
    bool checkValidString(string s) {
        stack<int> left_stack;
        stack<int> star_stack;
        for (size_t i = 0; i < s.size(); ++i) {
            if (s[i] == '(') {
                left_stack.push(i);
            } else if (s[i] == '*') {
                star_stack.push(i);
            } else if (s[i] == ')') {
                if (!left_stack.empty()) {
                    left_stack.pop();
                } else if (!star_stack.empty()) {
                    star_stack.pop();
                } else {
                    return false;
                }
            }
        }
        while (!left_stack.empty() && !star_stack.empty()) {
            if (left_stack.top() > star_stack.top()) {
                return false;
            } else {
                left_stack.pop();
                star_stack.pop();
            }
        }
        return left_stack.empty();
    }
};
相关推荐
数研小生1 小时前
构建命令行单词记忆工具:JSON 词库与艾宾浩斯复习算法的完美结合
算法·json
芒克芒克1 小时前
LeetCode 题解:除自身以外数组的乘积
算法·leetcode
Python 老手2 小时前
Python while 循环 极简核心讲解
java·python·算法
@Aurora.2 小时前
优选算法【专题九:哈希表】
算法·哈希算法·散列表
爱看科技2 小时前
微美全息(NASDAQ:WIMI)研究拜占庭容错联邦学习算法,数据安全与隐私保护的双重保障
算法
qq_417129252 小时前
C++中的桥接模式变体
开发语言·c++·算法
YuTaoShao3 小时前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
XH华4 小时前
备战蓝桥杯,第七章:函数与递归
职场和发展·蓝桥杯
吴维炜4 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
Σίσυφος19005 小时前
PCL Point-to-Point ICP详解
人工智能·算法