【問題】給出一個字符串 s(僅含有小寫英文字母和括號)。
請你按照從括號內到外的順序,逐層反轉每對匹配括號中的字符串,並返回最終的結果。
注意,您的結果中 不應 包含任何括號。
示例 1: 輸入:s = "(abcd)" 輸出:"dcba"
示例 2: 輸入:s = "(u(love)i)" 輸出:"iloveu"
示例 3: 輸入:s = "(ed(et(oc))el)" 輸出:"leetcode"
示例 4: 輸入:s = "a(bcdefghijkl(mno)p)q" 輸出:"apmnolkjihgfedcbq"
提示:
0 <= s.length <= 2000
s 中只有小寫英文字母和括號
我們確保所有括號都是成對出現的
【題解】
class Solution { public: string reverseParentheses(string s) { int len = s.length(); stack<int> sk; for(int i=0;i<len;++i){ char c = s[i]; if(c == '(') sk.push(i); else if(c == ')'){ auto it = sk.top(); sk.pop(); reverse(s.begin()+it+1,s.begin()+i); } } auto it = s.begin(),e = s.end(); while(it!=e){ if(*it=='(' || *it==')') it = s.erase(it); else ++it; } return s; } };