前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode - 使括号有效的最少添加

LeetCode - 使括号有效的最少添加

作者头像
晓痴
发布2019-07-24 14:12:44
4500
发布2019-07-24 14:12:44
举报
文章被收录于专栏:曌的晓痴曌的晓痴

LeetCode第921题,难度为中等。这又是一题括号相关的题目。

原题地址:https://leetcode-cn.com/problems/minimum-add-to-make-parentheses-valid/

题目描述

给定一个由 '(' 和 ')' 括号组成的字符串 S,我们需要添加最少的括号( '(' 或是 ')',可以在任何位置),以使得到的括号字符串有效。

从形式上讲,只有满足下面几点之一,括号字符串才是有效的:

它是一个空字符串,或者

它可以被写成 AB (A 与 B 连接), 其中 A 和 B 都是有效字符串,或者

它可以被写作 (A),其中 A 是有效字符串。

给定一个括号字符串,返回为使结果字符串有效而必须添加的最少括号数。

示例 1:

输入:"())"

输出:1

示例 2:

输入:"((("

输出:3

示例 3:

输入:"()"

输出:0

示例 4:

输入:"()))(("

输出:4

提示:

  1. S.length <= 1000
  2. S 只包含 '(' 和 ')' 字符。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/minimum-add-to-make-parentheses-valid

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

又是一题和括号是否有效相关的题目。所以就用老朋友栈来做辅助。

每次都将左括号(放入栈中,遇到右括号就将(从栈中取出来。最后还无法配对的左括号(数量就是栈中元素的大小了。

中文官网题解:

https://leetcode-cn.com/problems/minimum-add-to-make-parentheses-valid/solution/

个人题解:

代码语言:javascript
复制
class Solution {
    public int minAddToMakeValid(String S) {
         Stack<Character> stack = new Stack<>();
        for (char c : S.toCharArray()) {
            if (stack.empty()) {
                stack.push(c);
            } else {
                char sc = stack.pop();
                if (!(sc == '(' && c == ')')) {
                    stack.push(sc);
                    stack.push(c);
                }
            }
        }
        return stack.size();
    }
}

结果:

......(贴上自己的代码的运行结果)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-07-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 曌的晓痴 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档