Algorithm to Count the Minimum Add to Make Parentheses Valid
- 时间:2020-09-24 11:54:15
- 分类:网络文摘
- 阅读:122 次
Given a string S of ‘(‘ and ‘)’ parentheses, we add the minimum number of parentheses ( ‘(‘ or ‘)’, and in any positions ) so that the resulting parentheses string is valid.
Formally, a parentheses string is valid if and only if:
- It is the empty string, or
- It can be written as AB (A concatenated with B), where A and B are valid strings, or
- It can be written as (A), where A is a valid string.
Given a parentheses string, return the minimum number of parentheses we must add to make the resulting string valid.
Example 1:
Input: “())”
Output: 1Example 2:
Input: “(((”
Output: 3Example 3:
Input: “()”
Output: 0Example 4:
Input: “()))((”
Output: 4Note:
S.length <= 1000
S only consists of ‘(‘ and ‘)’ characters.
Parentheses Balance Algorithm
The algorithm is to count the number of the left Parentheses and, if we meet right Parentheses, we increment the answer if there is no enough left Parentheses, or we decrement the counter as to close the corresponding left Parentheses.
The final answer (the minimal add) plus the counter of the left Parentheses as we need to add to close them.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | class Solution { public: int minAddToMakeValid(string S) { int left = 0; int ans = 0; for (const auto &n: S) { if (n == '(') { left ++; } else { if (left > 0) { left --; } else { ans ++; } } } return ans + left; } }; |
class Solution {
public:
int minAddToMakeValid(string S) {
int left = 0;
int ans = 0;
for (const auto &n: S) {
if (n == '(') {
left ++;
} else {
if (left > 0) {
left --;
} else {
ans ++;
}
}
}
return ans + left;
}
};O(N) time as we need to scan the entire string and O(1) space, obviously.
–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:Subtract the Product and Sum of Digits of an Integer Leetcode’s Online Code Debugger Algorithm to Remove a Interval from Segments How to Start a Podcast for a Blog How to Change Your Blogging Focus Without Missing a Beat A 7-Step Guide to Creating Your Content Editorial Calendar for 2 How to Find and Hire a Ghostwriter for Your Blog Showcase About the Best 30+ Web Tools and Services on the Market 3 Incredible Landing Pages And What We Can Learn From Them What is Cycle Counting and How to Implement It in Your Retail Bu
- 评论列表
-
- 添加评论