Open carloscn opened 1 year ago
我们建立栈结构对括号进行匹配,遍历整个字符串,遇到匹配的括号则出栈:
pub fn remove_outer_parentheses(s: String) -> String
{
let mut ret_str = String::new();
if s.len() < 1 {
return ret_str;
}
let s_char_vec:Vec<char> = s.chars().collect();
let mut s_stack:Vec<char> = vec![];
let mut i:usize = 0;
let mut start:usize = 1;
while i < s.len() {
let c = s_char_vec[i];
if (s_stack.len() > 0) &&
('(' == s_stack[s_stack.len() - 1]) &&
(')' == c) {
s_stack.pop();
} else {
s_stack.push(c);
}
if s_stack.is_empty() {
for j in start..i {
print!("{} ", s_char_vec[j]);
ret_str.push(s_char_vec[j]);
}
start = i + 2;
}
i += 1;
}
return ret_str;
}
问题描述
有效括号字符串为空 ""、"(" + A + ")" 或 A + B ,其中 A 和 B 都是有效的括号字符串,+ 代表字符串的连接。
例如,"","()","(())()" 和 "(()(()))" 都是有效的括号字符串。 如果有效字符串 s 非空,且不存在将其拆分为 s = A + B 的方法,我们称其为原语(primitive),其中 A 和 B 都是非空有效括号字符串。
给出一个非空有效字符串 s,考虑将其进行原语化分解,使得:s = P_1 + P_2 + ... + P_k,其中 P_i 是有效括号字符串原语。
对 s 进行原语化分解,删除分解中每个原语字符串的最外层括号,返回 s 。
示例 1:
输入:s = "(()())(())" 输出:"()()()" 解释: 输入字符串为 "(()())(())",原语化分解得到 "(()())" + "(())", 删除每个部分中的最外层括号后得到 "()()" + "()" = "()()()"。
示例 2:
输入:s = "(()())(())(()(()))" 输出:"()()()()(())" 解释: 输入字符串为 "(()())(())(()(()))",原语化分解得到 "(()())" + "(())" + "(()(()))", 删除每个部分中的最外层括号后得到 "()()" + "()" + "()(())" = "()()()()(())"。
示例 3:
输入:s = "()()" 输出:"" 解释: 输入字符串为 "()()",原语化分解得到 "()" + "()", 删除每个部分中的最外层括号后得到 "" + "" = ""。
提示:
1 <= s.length <= 105 s[i] 为 '(' 或 ')' s 是一个有效括号字符串
来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/remove-outermost-parentheses 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。