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;      

       }

   };

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

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

目录
相关文章
|
10小时前
|
存储 C语言 索引
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
|
10小时前
LeetCode | 20. 有效的括号
LeetCode | 20. 有效的括号
|
10小时前
|
算法 索引
【刷题】滑动窗口精通 — Leetcode 30. 串联所有单词的子串 | Leetcode 76. 最小覆盖子串
经过这两道题目的书写,相信大家一定深刻认识到了滑动窗口的使用方法!!! 下面请大家继续刷题吧!!!
10 0
|
10小时前
leetcode代码记录(有效的括号
leetcode代码记录(有效的括号
11 1
|
10小时前
|
算法 安全 Java
【数据结构与算法】6、栈(Stack)的实现、LeetCode:有效的括号
【数据结构与算法】6、栈(Stack)的实现、LeetCode:有效的括号
22 0
|
10小时前
|
Java
|
10小时前
LeetCode题 338比特位计数,20有效的括号,415字符串相加
LeetCode题 338比特位计数,20有效的括号,415字符串相加
37 0
|
10小时前
leetcode:20. 有效的括号
leetcode:20. 有效的括号
13 0
|
10小时前
|
算法 测试技术 C#
【滑动窗口】【map】LeetCode:76最小覆盖子串
【滑动窗口】【map】LeetCode:76最小覆盖子串
|
10小时前
|
算法 测试技术 C#
【滑动窗口】LeetCode:30串联所有单词的子串
【滑动窗口】LeetCode:30串联所有单词的子串