301 Remove Invalid Parentheses 删除无效的括号
生活随笔
收集整理的這篇文章主要介紹了
301 Remove Invalid Parentheses 删除无效的括号
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
刪除最小數目的無效括號,使輸入的字符串有效,返回所有可能的結果。
注意: 輸入可能包含了除 ( 和 ) 以外的元素。
示例 :
"()())()" -> ["()()()", "(())()"]
"(a)())()" -> ["(a)()()", "(a())()"]
")(" -> [""]
詳見:https://leetcode.com/problems/remove-invalid-parentheses/description/
方法一:
class Solution {
public: vector<string> removeInvalidParentheses(string s) { vector<string> ans; helperDFS(s, ')', 0,ans); return ans; } void helperDFS(string s, char ch, int last,vector<string> &ans) { for(int i = 0, cnt = 0; i < s.size(); i++) { if(s[i]=='('||s[i]==')'){s[i]==ch?cnt++:cnt--; }if(cnt <= 0){continue; }for(int j = last; j <= i; j++) { if(s[j] == ch && (j ==last || s[j-1]!= ch)) {helperDFS(s.substr(0, j)+s.substr(j+1), ch, j,ans); }} return; } reverse(s.begin(), s.end()); if(ch == ')'){return helperDFS(s, '(', 0,ans); }ans.push_back(s); }
};
?方法二:
class Solution {
public:vector<string> removeInvalidParentheses(string s) {vector<string> res;unordered_set<string> visited{{s}};queue<string> q{{s}};bool found = false;while (!q.empty()){string t = q.front();q.pop();if (isValid(t)) {res.push_back(t);found = true;}if (found){continue;}for (int i = 0; i < t.size(); ++i) {if (t[i] != '(' && t[i] != ')'){continue;}string str = t.substr(0, i) + t.substr(i + 1);if (!visited.count(str)) {q.push(str);visited.insert(str);}}}return res;}bool isValid(string t) {int cnt = 0;for (int i = 0; i < t.size(); ++i) {if (t[i] == '('){++cnt;}else if (t[i] == ')' && --cnt < 0){return false;}}return cnt == 0;}
};
?參考:https://blog.csdn.net/qq508618087/article/details/50408894
https://www.cnblogs.com/grandyang/p/4944875.html
轉載于:https://www.cnblogs.com/xidian2014/p/8781578.html
總結
以上是生活随笔為你收集整理的301 Remove Invalid Parentheses 删除无效的括号的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 我的常用npm命令
- 下一篇: 电影有约是个节目吗?听说里面还有明星同款