【LeetCode每日一题】——301.删除无效的括号

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【题目提示】
  • 七【解题思路】
  • 八【时间频度】
  • 九【代码实现】
  • 十【提交结果】

一【题目类别】

  • 广度优先搜索

二【题目难度】

  • 困难

三【题目编号】

  • 301.删除无效的括号

四【题目描述】

  • 给你一个由若干括号和字母组成的字符串 s ,删除最小数量的无效括号,使得输入的字符串有效。
  • 返回所有可能的结果。答案可以按 任意顺序 返回。

五【题目示例】

  • 示例 1:

    • 输入:s = "()())()"
    • 输出:["(())()","()()()"]
  • 示例 2:

    • 输入:s = "(a)())()"
    • 输出:["(a())()","(a)()()"]
  • 示例 3:

    • 输入:s = ")("
    • 输出:[""]

六【题目提示】

  • 1 <= s.length <= 25
  • s 由小写英文字母以及括号 '('')' 组成
  • s 中至多含 20 个括号

七【解题思路】

  • 这道题我觉得还是挺难的,虽然没用到什么特别的算法,不过很难想到(我个人感觉)
  • 要解决这道题我们首先要考虑使用什么方法,我们仔细阅读题目后发现一个细节,即删除最少数量的无效括号以达到目的
  • 既然要最少数量,我们想是不是可以每次删除一个括号,然后下一次以每次删除后的结果继续向下删除括号以测试现在的括号是否有效呢?
  • 这个思路显然是可以的,并且由于每次只删除一个括号,所以显然满足题目要求的最少次数,而且自然的想到了广度优先搜索:
    • 队列中初始化为输入字符串
    • 然后进入广度优先遍历算法
    • 每次首先判断当前得到的字符串中是否存在满足要求的括号序列(写一个函数判断,这个很简单)
      • 如果存在满足要求的括号序列,直接返回结果即可
      • 如果不存在满足要求的括号序列,就在上次处理的结果上,继续逐个删除括号,在下一层继续判断是否存在满足要求的括号序列
    • 最后返回结果即可
  • 具体细节可以参考下面的代码

八【时间频度】

  • 时间复杂度: O ( n × 2 n ) O(n \times 2^n) O(n×2n) n n n为字符串的长度
  • 空间复杂度: O ( n × C n n 2 ) O(n \times C_{n}^{\frac{n}{2}}) O(n×Cn2n) n n n为字符串的长度

九【代码实现】

  1. Java语言版
class Solution {public List<String> removeInvalidParentheses(String s) {// 存储结果List<String> res = new ArrayList<String>();// 存储当前层字符串的集合(去重)Set<String> curLevel = new HashSet<String>();curLevel.add(s);// 使用广度优先遍历算法删除无效的括号while (true) {// 查看当前层字符串的集合是否存在满足要求的字符串序列for (String str : curLevel) {if (isValid(str)) {res.add(str);}}// 若找到满足要求的字符串序列,直接返回if (res.size() > 0) {return res;}// 存储下一层字符串的集合(去重)Set<String> nextLevel = new HashSet<String>();// 根据上一层的结果计算下一层的字符序列for (String str : curLevel) {for (int i = 0; i < str.length(); i++) {// 避免重复计算if (i > 0 && str.charAt(i) == str.charAt(i - 1)) {continue;}// 每个位置的括号都要删除一次if (str.charAt(i) == '(' || str.charAt(i) == ')') {nextLevel.add(str.substring(0, i) + str.substring(i + 1, str.length()));}}}// 开始以下一层为基准进行下一批次的遍历curLevel = nextLevel;}}// 判断给定的括号序列是否有效private boolean isValid(String str) {char[] strs = str.toCharArray();int count = 0;for (char s : strs) {if (s == '(') {count++;} else if (s == ')') {count--;if (count < 0 ) {return false;}}}return count == 0;}}
  1. Python语言版
class Solution:def removeInvalidParentheses(self, s: str) -> List[str]:# 判断给定的括号序列是否有效def isValid(string):count = 0for s in string:if s == "(":count += 1elif s == ")":count -= 1if count < 0:return Falsereturn count == 0# 存储结果res = []# 存储当前层字符串的集合(去重)cur_level = set([s])# 使用广度优先遍历算法删除无效的括号while True:# 查看当前层字符串的集合是否存在满足要求的字符串序列for string in cur_level:if isValid(string):res.append(string)# 若找到满足要求的字符串序列,直接返回if len(res) > 0:return res# 存储下一层字符串的集合(去重)next_level = set()# 根据上一层的结果计算下一层的字符序列for string in cur_level:for i in range(len(string)):# 避免重复计算if i > 0 and string[i] == s[i - 1]:continue# 每个位置的括号都要删除一次if string[i] == "(" or string[i] == ")":next_level.add(string[:i] + string[i + 1:])# 开始以下一层为基准进行下一批次的遍历cur_level = next_level# 返回结果return res
  1. C++语言版
class Solution {
public:// 判断给定的括号序列是否有效bool isValid(string str) {int count = 0;for (char s : str) {if (s == '(') {count++;} else if (s == ')') {count--;if (count < 0) {return false;}}}return count == 0;}vector<string> removeInvalidParentheses(string s) {// 存储结果vector<string> res;// 存储当前层字符串的集合(去重)unordered_set<string> curLevel;curLevel.insert(s);// 使用广度优先遍历算法删除无效的括号while(true) {// 查看当前层字符串的集合是否存在满足要求的字符串序列for (auto & str : curLevel) {if (isValid(str)) {res.emplace_back(str);}}// 找到满足要求的字符串序列,直接返回if (res.size() > 0) {return res;}// 存储下一层字符串的集合(去重)unordered_set<string> nextLevel;// 根据上一层的结果计算下一层的字符序列for (auto & str : curLevel) {for(int i = 0; i < str.size(); i++) {// 避免重复计算if(i > 0 && str[i] == str[i - 1]) {continue;}// 每个位置的括号都要删除一次if (str[i] == '(' || str[i] == ')') {nextLevel.insert(str.substr(0, i) + str.substr(i + 1, str.size()));}}}// 开始以下一层为基准进行下一批次的遍历curLevel = nextLevel;}// 返回结果return res;}
};

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. Python语言版
    在这里插入图片描述

  3. C++语言版
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/52051.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ROS 2中,CMakeList.txt常见语法

在ROS 2中&#xff0c;CMakeList.txt 文件扮演着配置和管理构建过程的重要角色。这个文件遵循CMake的语法&#xff0c;用于定义如何编译和链接源代码。下面是一些在ROS 2项目CMakeList.txt文件中常见的语法和用法。 1. 基本结构和命令 cmake_minimum_required(VERSION )&…

【设计模式】装饰器模式和适配模式

装饰器模式 装饰器模式能够很好的对已有功能进行拓展&#xff0c;这样不会更改原有的代码&#xff0c;对其他的业务产生影响&#xff0c;这方便我们在较少的改动下对软件功能进行拓展。 类似于 router 的前置守卫和后置守卫。 Function.prototype.before function (beforeFn)…

【C++】————智能指针

作者主页&#xff1a; 作者主页 本篇博客专栏&#xff1a;C 创作时间 &#xff1a;2024年8月20日 一&#xff0c;什么是智能指针 在C中没有垃圾回收机制&#xff0c;必须自己释放分配的内存&#xff0c;否则就会造成内存泄露。解决这个问题最有效的方法是使用智能指针&…

异常信息转储预研笔记-堆栈地址转换

addr2line命令 addr2line -e <exec> <addr> -f | xargs cfilt<exec>: 进程名 <addr>&#xff1a;堆栈地址eg&#xff1a; addr2line -e backtrace 0x4009d2 -f | xargs cfilt此方案测试了&#xff0c;不知道什么原因只显示?? ??:0 &#xff0c;而…

Java面试题--分布式锁

分布式锁 你说一下什么是分布式锁 分布式锁是在分布式/集群环境中解决多线程并发造成的一系列数据安全问题.所用到的锁就是分布式锁&#xff0c;这种锁需要被多个应用共享才可以&#xff0c;通常使用Redis和zookeeper来实现。 分布式锁有哪些解决方案 常用的三种方案 基于…

Spring模块详解Ⅱ

目录 Spring Beans模块详解1. 什么是 Bean?2. Spring Bean的配置方式2.1 基于 XML 配置例子&#xff1a; 2.2 基于注解配置例子&#xff1a; 2.3 基于 Java 配置&#xff08;JavaConfig&#xff09;例子&#xff1a; 3. Bean 的生命周期生命周期回调的例子&#xff1a; 4. Bea…

Oracle+ASM+High冗余详解及空间计算

Oracle ASM&#xff08;Automatic Storage Management&#xff09;的High冗余模式是一种提供高度数据保护的策略&#xff0c;它通过创建多个数据副本来确保数据的可用性和安全性。 以下是关于Oracle ASM High冗余的详细解释&#xff1a; 一、High冗余的特点 1.数据冗余度 在Hi…

极速闪存启动:SD与SPI模式的智能初始化指南

最近很多客户朋友在询问我们 CS 创世 SD NAND 能不能使用 SPI 接口&#xff0c;两者使用起来有何区别&#xff0c;下面为大家详细解答。 SD MODE: CS 创世 SD NAND 支持 SD 模式和 SPI 模式&#xff0c;SD NAND 默认为 SD 模式&#xff0c;上电后&#xff0c;其初始化过程如下…

链游:基于telegram和TON wallet在mac本地运行Flappy bird项目

【好看的灵魂千篇一律,有趣的鲲志一百六七!】- 可查看详情~~ 作者:鲲志说 (公众号、B站同名,视频号:鲲志说996) 后端研发:java、go,前电商、现web3 博客专家:阿里云社区、CSDN博客专家 超级个体:COC杭州开发者社区主理人 AI爱好者: AI电影共创社杭州核心成员…

【Word多级标题完整设置】设置各级标题样式将多级列表链接到各级标题样式中

Word多级标题完整设置 一、设置各级标题样式主标题样式设置中英文字体、字形以及字号设置段落设置&#xff08;缩进、间距和行距&#xff09; 一级标题样式设置中英文字体、字形以及字号设置段落设置&#xff08;缩进、间距和行距&#xff09; 二级标题样式设置中英文字体、字形…

深度学习基础—Batch Norm

对于一个神经网络我们知道&#xff0c;归一化输入特征是加速网络训练的技巧之一&#xff0c;因为归一化后&#xff0c;损失函数的图像就会由狭长变得更圆&#xff0c;那么这是否启发我们&#xff0c;在深度更深模型中&#xff0c;对各层的输出进行归一化&#xff0c;有益于下一…

day6 测试基础知识积累

JMeter 服务端系统性能测试是针对服务器端应用程序或服务 在特定负载下的运行能力和稳定性进行评估的方法。 产品文档应该有产品的性能指标&#xff0c;做性能测试前&#xff0c;如果需求文档没有性能指标则要向产品团队要。服务端系统性能测试 的常见指标有&#xff1a;TPS、…

Go 1.21在性能方面有哪些提升?

Go 1.21版本在性能方面取得了多项重要进展&#xff0c;主要体现在以下几个方面&#xff1a; 1. Profile-Guided Optimization (PGO) Go 1.21正式推出了PGO功能&#xff0c;使用PGO构建的Go程序性能通常可提升2-7%[2][5]。编译器本身也采用了PGO优化&#xff0c;使得编译速度提…

Abstract Class抽象类

抽象类&#xff08;Abstract Class&#xff09;在面向对象编程中是一种特殊的类&#xff0c;它不能被实例化&#xff0c;即不能创建该类的对象。抽象类主要用于定义一组接口&#xff08;即方法&#xff09;&#xff0c;这些方法的具体实现由子类来完成。抽象类通常用于表示一种…

ebpf教程(4.1):XDP程序的加载

文章目录 前言环境准备加载XDP程序源码构建过程运行 前言 前置阅读要求&#xff1a; ebpf教程(3):使用cmake构建ebpf项目-CSDN博客[译] [论文] XDP (eXpress Data Path)&#xff1a;在操作系统内核中实现快速、可编程包处理&#xff08;ACM&#xff0c;2018&#xff09;xdp-t…

C++中数据类型的学习

目录 一、整形 二、sizeof关键字 三、实型&#xff08;浮点型&#xff09; 四、字符型 五、转义字符 六、字符串型 七、布尔类型bool 八、数据的输入 数据类型 C规定在创建一个变量或者常量时&#xff0c;必须要指定出相应的数据类型&#xff0c;否则无法给变量分配内…

Java设计模式之中介者模式(Mediator Pattern)

Java设计模式之中介者模式&#xff08;Mediator Pattern&#xff09; 引言 在软件开发中&#xff0c;设计模式是解决常见设计问题的一系列最佳实践。中介者模式&#xff08;Mediator Pattern&#xff09;是行为型设计模式之一&#xff0c;它的主要目的是减少对象之间的直接相…

kubeadm搭建生产环境高可用集群

前言 搞了好多天&#xff08;今天是20240819&#xff09;&#xff0c;中途遇到各种各样的问题&#xff0c;总算是可以用了 我这里用的vmware开了5台服务器做学习实践 K8S因为直接使用的 pkgs.k8s.io 仓库&#xff0c;所以直接拉取的最新release版&#xff08;v1.31&#xff09…

SIRA-PCR: Sim-to-Real Adaptation for 3D Point Cloud Registration 论文解读

目录 一、导言 二、 相关工作 1、三维点云配准工作 2、无监督域适应 三、SIRA-PCR 1、FlyingShape数据集 2、Sim-to-real自适应方法 3、配准 4、损失函数 一、导言 该论文来自于ICCV2023&#xff0c;论文提出了一种新的方法SIRA-PCR&#xff0c;通过利用合成数据Flying…

网易云音乐故障 2 小时,这次到底谁背锅?(今天记得领补偿)

大家好&#xff0c;我是程序员鱼皮&#xff0c;8 月 19 日下午&#xff0c;网易云音乐突发严重故障&#xff0c;并登顶微博热搜&#xff0c;跟黑神话悟空抢了热度。 根据用户的反馈&#xff0c;故障的具体表现为&#xff1a;用户无法登录、歌单加载失败、播放信息获取失败、无法…