921. 使括号有效的最少添加
921. Minimum Add to Make Parentheses Validjava
题目描述
给定一个由 '(' 和 ')' 括号组成的字符串 S,咱们须要添加最少的括号( '(' 或是 ')',能够在任何位置),以使获得的括号字符串有效。算法
从形式上讲,只有知足下面几点之一,括号字符串才是有效的:spa
给定一个括号字符串,返回为使结果字符串有效而必须添加的最少括号数。code
每日一算法2019/6/20Day 48LeetCode921. Minimum Add to Make Parentheses Validleetcode
示例 1:
字符串
示例 2:
get
示例 3:
io
示例 4:
class
提示:import
Java 实现
import java.util.ArrayDeque; import java.util.Deque; class Solution { public int minAddToMakeValid(String S) { Deque<Character> deque = new ArrayDeque<>(); int count = 0; for (char c : S.toCharArray()) { if (c == '(') { deque.push(c); } else if (deque.isEmpty()) { count++; } else { deque.pop(); } } return deque.size() + count; } }
参考资料