【数据结构-合法括号字符串】力扣921. 使括号有效的最少添加

给定一个括号字符串 s ,在每次操作中,你可以在字符串的任何位置插入一个括号。

例如,如果 s = "()))" ,你可以插入一个左括号变成 "(()))",或者插入一个右括号变成 "())))" 。

返回 为使结果字符串 s 有效而必须添加的最少括号数。

有效字符串指的是,每个左括号都会有一个对应的右括号。

示例 1:

输入:s = "())"

输出:1

示例 2:

输入:s = "((("

输出:3

提示:

1 <= s.length <= 1000

s 只包含 '(' 和 ')' 字符。

模拟栈

cpp 复制代码
class Solution {
public:
    int minAddToMakeValid(string s) {
        int res = 0;
        vector<int> st;
        for(char c : s){
            if(c == '('){
                st.push_back(c);
                res++;
            }
            else{
                if(!st.empty() && st.back() == '('){
                    st.pop_back();
                    res--;
                }
                else{
                    res++;
                }
            }
        }
        return res;
    }
};

时间复杂度:O(n)
空间复杂度:O(n)

我们可以采用模拟栈的方法,使用一个变量res来记录未匹配括号的个数,在遍历字符串中,如果遍历到左括号,则另res++,遍历到右括号,如果栈顶元素是左括号,则将他们匹配,res--。如果栈顶元素不是左括号或者是空栈,则令res++。

空间优化

cpp 复制代码
class Solution {
public:
    int minAddToMakeValid(string s) {
        int ans = 0;
        int leftCount = 0;
        for (auto &c : s) {
            if (c == '(') {
                leftCount++;
            } else {
                if (leftCount > 0) {
                    leftCount--;
                } else {
                    ans++;
                }
            }
        }
        ans += leftCount;
        return ans;
    }
};

时间复杂度:O(n)
空间复杂度:O(1)

我们可以通过一个变量leftCount来记录未匹配左括号的个数,当遍历到左括号的时候,令leftCount++,当遍历到的元素是右括号的时候,如果在他左边有未匹配的左括号,则令他们匹配,然后leftCount--,否则右括号没有被匹配,我们将未匹配的右括号个数加入到ans中。最后遍历完后,我们需要添加括号的次数就是未匹配的左括号次数加上未匹配的右括号次数ans += leftCount

相关推荐
业精于勤的牙21 小时前
最长特殊序列(二)
java·开发语言·算法
yong999021 小时前
C#实现OPC客户端与S7-1200 PLC的通信
开发语言·网络·算法·c#
yaoh.wang21 小时前
力扣(LeetCode) 111: 二叉树的最小深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·深度优先
啊阿狸不会拉杆21 小时前
《数字图像处理》第 11 章 - 特征提取
图像处理·人工智能·算法·计算机视觉·数字图像处理
Yeats_Liao21 小时前
MindSpore开发之路(八):数据处理之Dataset(上)——构建高效的数据流水线
数据结构·人工智能·python·机器学习·华为
那雨倾城21 小时前
PiscCode实现用 YOLO 给现实世界加上「NPC 血条 HUD」
图像处理·python·算法·yolo·计算机视觉·目标跟踪
夏幻灵21 小时前
C++ 中手动重载赋值运算符(operator=)时实现部分复制的思路和方法
开发语言·c++·算法
九河云1 天前
人工智能驱动企业数字化转型:从效率工具到战略引擎
人工智能·物联网·算法·机器学习·数字化转型
王德博客1 天前
【题解】求分数序列(C++)
算法
再__努力1点1 天前
LBP纹理特征提取:高鲁棒性的纹理特征算法
开发语言·人工智能·python·算法·计算机视觉