1190 反转每对括号间的子串 leetcode

简介: 1190 反转每对括号间的子串 leetcode

给出一个字符串 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) {

           stack<int> sta;

           for(int i=0;i<s.size();i++)

           {

               char c=s[i];

               if(c=='(')

                   sta.push(i);

               else if(c==')')

               {    int w=sta.top();

                     sta.pop();

                   reverse(s.begin()+w+1,s.begin()+i);  

               }

 

           }

             auto x=s.begin(),y=s.end();

               while(x!=y)

               {  if(*x=='('||*x==')')

                     s.erase(x);

                  else

                      x++;

               }

             return s;      

       }

   };

分为两步:利用栈的特点,先找出字符串最里面括号内容并反转,再找出次里面的反转,直到没有括号。

再利用迭代器寻找括号并删除

目录
相关文章
|
14天前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
1月前
|
算法 C++
Leetcode第二十二题(括号生成)
这篇文章讨论了如何使用递归算法解决LeetCode第22题“括号生成”的问题,提供了两种C++的实现方法,目的是生成所有有效的括号组合。
17 0
Leetcode第二十二题(括号生成)
|
1月前
|
存储 C++ 容器
Leetcode第二十题(有效的括号)
这篇文章介绍了如何使用栈来解决LeetCode第20题“有效的括号”问题,提供了两种方法:数组栈和容器栈,以及相应的C++代码实现。
17 0
|
3月前
|
算法
LeetCode第22题括号生成
该文章介绍了 LeetCode 第 22 题括号生成的解法,通过回溯算法生成所有可能的括号组合,在递归过程中根据左右括号数量的条件进行剪枝,从而得到有效的括号组合。
LeetCode第22题括号生成
|
3月前
|
存储 算法
LeetCode第20题有效的括号
该文章介绍了 LeetCode 第 20 题有效的括号的解法,通过分析有效括号的特征,使用栈结构存储括号关系,判断遇到右边括号时栈顶是否有匹配的左边括号,从而解决问题,同时总结了栈的先进后出结构可用于解决有规律的符号匹配问题。
LeetCode第20题有效的括号
|
3月前
|
算法 Python
【Leetcode刷题Python】括号匹配问题
一种解决括号匹配问题的Python实现方法,通过计算给定括号串的所有子串的最长合法括号子序列长度之和来确定权值。
25 0
|
3月前
|
机器学习/深度学习 Python
【Leetcode刷题Python】22. 括号生成
本文介绍了了LeetCode题目22的两种Python编程解决方案,题目要求生成所有可能的且有效的括号组合,包括暴力求解和回溯方法。
26 0
|
3月前
|
Python
【Leetcode刷题Python】20. 有效的括号
LeetCode上题目“20. 有效的括号”的Python解决方案,使用栈数据结构来验证括号序列的有效性。具体实现中,会在栈中预先放置一个特殊字符以避免在弹出操作时出现空栈错误,并通过匹配左右括号来判断括号序列是否有效。
43 0
|
5月前
|
存储 算法 测试技术
力扣经典150题第三十三题:最小覆盖子串
力扣经典150题第三十三题:最小覆盖子串
37 1
|
4月前
|
算法 测试技术
力扣经典150题第五十一题:有效的括号
力扣经典150题第五十一题:有效的括号
37 0