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

相关推荐
远远远远子9 小时前
类与对象 --1
开发语言·c++·算法
Aaplloo9 小时前
【无标题】
人工智能·算法·机器学习
西望云天9 小时前
The 2024 ICPC Asia Nanjing Regional Contest(2024南京区域赛EJKBG)
数据结构·算法·icpc
10岁的博客9 小时前
容器化安装新玩法
算法
不会算法的小灰9 小时前
HTML简单入门—— 基础标签与路径解析
前端·算法·html
flashlight_hi11 小时前
LeetCode 分类刷题:1901. 寻找峰值 II
python·算法·leetcode
深瞳智检11 小时前
YOLO算法原理详解系列 第007期-YOLOv7 算法原理详解
人工智能·算法·yolo·目标检测·计算机视觉·目标跟踪
郝学胜-神的一滴11 小时前
中秋特别篇:使用QtOpenGL和着色器绘制星空与满月
开发语言·c++·算法·软件工程·着色器·中秋
qiuiuiu41312 小时前
CPrimer Plus第十六章C预处理器和C库总结2-qsort函数
java·c语言·算法