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;      

       }

   };

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

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

目录
相关文章
|
4天前
|
算法
LeetCode第22题括号生成
该文章介绍了 LeetCode 第 22 题括号生成的解法,通过回溯算法生成所有可能的括号组合,在递归过程中根据左右括号数量的条件进行剪枝,从而得到有效的括号组合。
LeetCode第22题括号生成
|
4天前
|
存储 算法
LeetCode第20题有效的括号
该文章介绍了 LeetCode 第 20 题有效的括号的解法,通过分析有效括号的特征,使用栈结构存储括号关系,判断遇到右边括号时栈顶是否有匹配的左边括号,从而解决问题,同时总结了栈的先进后出结构可用于解决有规律的符号匹配问题。
LeetCode第20题有效的括号
|
14天前
|
算法 Python
【Leetcode刷题Python】括号匹配问题
一种解决括号匹配问题的Python实现方法,通过计算给定括号串的所有子串的最长合法括号子序列长度之和来确定权值。
9 0
|
15天前
|
机器学习/深度学习 Python
【Leetcode刷题Python】22. 括号生成
本文介绍了了LeetCode题目22的两种Python编程解决方案,题目要求生成所有可能的且有效的括号组合,包括暴力求解和回溯方法。
11 0
|
15天前
|
Python
【Leetcode刷题Python】20. 有效的括号
LeetCode上题目“20. 有效的括号”的Python解决方案,使用栈数据结构来验证括号序列的有效性。具体实现中,会在栈中预先放置一个特殊字符以避免在弹出操作时出现空栈错误,并通过匹配左右括号来判断括号序列是否有效。
7 0
|
2月前
|
存储 算法 测试技术
力扣经典150题第三十三题:最小覆盖子串
力扣经典150题第三十三题:最小覆盖子串
14 1
|
2月前
|
算法
【LeetCode刷题】滑动窗口解决问题:串联所有单词的子串(困难)、最小覆盖子串(困难)
【LeetCode刷题】滑动窗口解决问题:串联所有单词的子串(困难)、最小覆盖子串(困难)
|
1月前
|
算法 测试技术
力扣经典150题第五十一题:有效的括号
力扣经典150题第五十一题:有效的括号
22 0
|
2月前
|
算法 测试技术 索引
力扣经典150题第三十二题:串联所有单词的子串
力扣经典150题第三十二题:串联所有单词的子串
15 0
|
2月前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成