【数据结构-合法括号字符串】力扣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

相关推荐
AICodeThunder7 分钟前
【S组篇】C++知识点总结(1):并查集基础
c语言·数据结构·c++·算法·图论
南方的狮子先生13 分钟前
【逻辑回归】从线性模型到逻辑回归
算法·机器学习·逻辑回归
闻缺陷则喜何志丹34 分钟前
【排序】P9127 [USACO23FEB] Equal Sum Subarrays G|普及+
c++·算法·排序·洛谷
Code_Shark1 小时前
AtCoder Beginner Contest 424 题解
数据结构·c++·算法·数学建模·青少年编程
CS创新实验室1 小时前
深入解析快速排序(Quicksort):从原理到实践
数据结构·算法·排序算法·快速排序
Dream it possible!1 小时前
LeetCode 面试经典 150_链表_反转链表 II(60_92_C++_中等)(头插法)
c++·leetcode·链表·面试
yeshihouhou2 小时前
树 B树和B+树
数据结构
大数据张老师2 小时前
数据结构——B+树的基本概念
数据结构·1024程序员节
草莓工作室2 小时前
数据结构12:二叉树的API及其实现
c语言·数据结构·二叉树
Theodore_10223 小时前
深度学习(3)神经网络
人工智能·深度学习·神经网络·算法·机器学习·计算机视觉