这是小川的第380次更新,第408篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第242题(顺位题号是1021)。有效的括号字符串为空("")"("+ A +")"A + B,其中A和B是有效的括号字符串,+表示字符串连接。例如,"""()""(())()""(()(()))"都是有效的括号字符串。

如果有效的括号字符串S是非空的,并且不存在将其拆分为S = A + B的方法,其中A和B是非空有效括号字符串,则它是原始的。

给定有效的括号字符串S,考虑其原始分解:S = P_1 + P_2 + ... + P_k,其中P_i是原始有效括号字符串。

在去除S的原语分解中的每个原始字符串的最外面的括号后返回S。例如:

输入:"(()())(())"

输出:"()()()"

说明:

输入字符串是"(()())(())",带有原语分解"(()())"+"(())"

删除每个部分的外括号后,"()()" + "()" = "()()()"

输入:"(()())(())(()(()))"

输出:"()()()()(())"

说明:

输入字符串是"(()())(())(()(()))",带原语分解"(()())"+"(())"+"(()(( )))"

删除每个部分的外括号后,"()()" + "()" + "()(())" = "()()()()(())"

输入:"()()"

输出:""

说明:

输入字符串是"()()",原始分解"()"+"()"

删除每个部分的外括号后,""+""=""。

注意

  • S.length <= 10000

  • S[i]"("")"

  • S是一个有效的括号字符串。

02 第一种解法

根据题目的描述和例子来看,是要找到S中的每一个原始有效字符串,然后去掉每个原始有效字符串的外层括号。

S中,左括号"("和右括号")"是成对出现的,即在每一个原始有效字符串中,左括号和右括号的数量是相同的。

思路:从左到右遍历S中的字符,定义两个变量leftright,记录遇到的左括号、右括号的数量,当左括号和右括号的数量相等时,说明遇到了一个原始有效字符串,去掉头尾的括号,借助字符串截取完成,拼接到StringBuilder中。

public String removeOuterParentheses(String S) {
StringBuilder sb = new StringBuilder();
int left = 0, right = 0, index = 0;
int n = S.length();
for (int i=0; i<n; i++) {
if (S.charAt(i) == '(') {
left++;
} else if (S.charAt(i) == ')') {
right++;
}
if (left == right) {
sb.append(S.substring(index+1, i));
index = i + 1;
}
}
return sb.toString();
}

03 第二种解法

思路和上面第一种解法类似,只是没有借助两个变量来计数,而是使用一个变量count,遇到左括号就加1,遇到右括号就减1,但是最开始的左括号和最后边的右括号时不能拼接进去的,所以当遇到左括号且count等于1的时候,要进入下一次循环,当遇到右括号且count等于0的时候,表明当前这个原始有效字符串中的括号已经遍历完了,需要进入下一次循环。

public String removeOuterParentheses2(String S) {
StringBuilder sb = new StringBuilder();
int count = 0, n = S.length();
for (int i=0; i<n; i++) {
if (S.charAt(i) == '(') {
count++;
if (count == 1) {
continue;
}
} else if(S.charAt(i) == ')') {
count--;
if (count == 0) {
continue;
}
}
sb.append(S.charAt(i));
}
return sb.toString();
}

04 小结

算法专题目前已连续日更超过七个月,算法题文章248+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode.1021-删除最外面的括号(Remove Outermost Parentheses)的更多相关文章

  1. LeetCode 1021. 删除最外层的括号(Remove Outermost Parentheses)

    1021. 删除最外层的括号 1021. Remove Outermost Parentheses 题目描述 有效括号字符串为空 ("")."(" + A + ...

  2. [Swift]LeetCode1021. 删除最外层的括号 | Remove Outermost Parentheses

    A valid parentheses string is either empty (""), "(" + A + ")", or A + ...

  3. leetcode 1021. 删除最外层的括号

    问题描述 有效括号字符串为空 ("")."(" + A + ")" 或 A + B,其中 A 和 B 都是有效的括号字符串,+ 代表字符串的 ...

  4. Leetcode之回溯法专题-22. 括号生成(Generate Parentheses)

    Leetcode之回溯法专题-22. 括号生成(Generate Parentheses) 给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合. 例如,给出 n ...

  5. 【Leetcode_easy】1021. Remove Outermost Parentheses

    problem 1021. Remove Outermost Parentheses 参考 1. Leetcode_easy_1021. Remove Outermost Parentheses; 完

  6. LeetCode--To Lower Case && Remove Outermost Parentheses (Easy)

    709. To Lower Case(Easy)# Implement function ToLowerCase() that has a string parameter str, and retu ...

  7. 1021. Remove Outermost Parentheses删除最外层的括号

    网址:https://leetcode.com/problems/remove-outermost-parentheses/ 使用栈的思想,选择合适的判断时机 class Solution { pub ...

  8. Leetcode 5016. 删除最外层的括号

    5016. 删除最外层的括号  显示英文描述 我的提交返回竞赛   用户通过次数446 用户尝试次数469 通过次数456 提交次数577 题目难度Easy 有效括号字符串为空 ("&quo ...

  9. 【leetcode】1021. Remove Outermost Parentheses

    题目如下: A valid parentheses string is either empty (""), "(" + A + ")", ...

随机推荐

  1. dirname命令和basename命令

    dirname返回文件所在目录路径,而basename则相反,去掉路径返回最后的文件名. direname: 用途 从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的 ...

  2. jquery $(".classc",$(".classp"))的含义

    jquery中有一种选择器的写法为:$(".classc",$(".classp")),注意,是$()中又嵌套了一个$(),这种写法的作用类似于$(" ...

  3. windows和linux开机自启动设置

    Windows 1,启动快捷方式   开始>程序>启动 文件夹中拷贝进去需要开机启动的程序快捷方法,此方法需要相应用户登录系统2,注册为服务,设置启动方式为自动   a,    sc命令  ...

  4. k8b部署prometheus+grafana

    来源: https://juejin.im/post/5c36054251882525a50bbdf0 https://github.com/redhatxl/k8s-prometheus-grafa ...

  5. CF 354 div2 B 酒杯金字塔

    B. Pyramid of Glasses time limit per test 1 second memory limit per test 256 megabytes input standar ...

  6. Vue-CLI项目搭建

    一.环境搭建 1.安装服务器node 官网下载 https://nodejs.org/zh-cn/ node:用C++语言编写,用来运行JavaScript语言 node可以为前端项目提供server ...

  7. JSP中EL表达式不能使用的问题

    在JSP2.0中,增加了EL语言,可以通过EL语言,可以通过EL语言,实现获取数据,进一步将scriptlet 代码从JSP页面中分离出来.EL语言给大家带来了方便,但有时,也会遇到EL表达式不能显示 ...

  8. 在spring官网上下载历史版本的spring插件,springsource-tool-suite

    目前spring官网(https://spring.io/tools3/sts/all)上可下载的spring插件只有: ECLIPSE ARCHIVE SIZE 4.9.0 springsource ...

  9. Dynamic Web Module 2.3 change to 3.0 maven工程解决办法

    pom.xml <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <a ...

  10. shiro.ini

    # # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreeme ...