【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,一经查实,立即删除!

相关文章

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

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

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;其初始化过程如下…

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

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

深度学习基础—Batch Norm

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

day6 测试基础知识积累

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

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

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

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;用户无法登录、歌单加载失败、播放信息获取失败、无法…

了解数据库中常用存储引擎数据结构(2)

目录 深入了解B树及其变种 BTree BTree B*Tree BTree并发机制 B-Link Tree 深入了解B树及其变种 先把我们要解释的B树变种都列出来&#xff0c;B树的变种主要有B树、B*树、B-Link树、COW B树、惰性B树、Bw树等。 下面具体来分析这些变种的优势和发展趋势。 BTree 下图…

Taro+Vue 创建微信小程序

TaroVue 创建微信小程序 一、全局安装 tarojs/cli二、项目初始化三、现在去启动项目吧 一、全局安装 tarojs/cli npm install -g tarojs/cli //安装 npm info tarojs/cli //查看安装信息 如果正常显示版本说明成功了&#xff0c;就直接跳到第二步吧官网说&#xff1a;…

AI产品经理如何入门?零基础入门到精通,收藏这一篇就够了

现在做产品经理&#xff0c;真的挺累的。 现在产品越来越难做&#xff0c;晋升困难&#xff0c;工资迟迟不涨……公司裁员&#xff0c;产品经理首当其冲&#xff01;&#xff01; 做产品几年了&#xff0c;还没升职&#xff0c;就先到了“职业天花板”。 想凭工作几年积累的…

BFS解决单源最短路问题

目录 迷宫中离入口最近的出口 最小基因变化 单词接龙 为高尔夫比赛砍树 迷宫中离入口最近的出口 题目 思路 使用宽度优先遍历解决这道题&#xff0c;需要一个二维数组标记是否被遍历过&#xff0c;也需要一个队列辅助完成宽度优先遍历&#xff0c;类似于水波纹一样&#x…

JAVA基础:File类

目录 前言 file对象的创建 file的常用方法 前言 file类表示的是系统中的一个文件或者文件夹 file类和系统中的文件或者文件夹不需要是一一对应的&#xff0c;我们可以在file类中写你系统中不存在的文件或文件夹 file类中存储的实际上是文件或文件夹的抽象路径&#xff0c…

面试经典算法150题系列-最长公共前缀

最长公共前缀 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀&#xff0c;返回空字符串 ""。 示例 1&#xff1a; 输入&#xff1a;strs ["flower","flow","flight"] 输出&#xff1a;"fl"示例 2&…

软件测试 - 自动化测试(概念)(Java)(自动化测试分类、web自动化测试、驱动、selenium自动化测试工具的安装)

一、自动化的概念 ⾃动洒⽔机&#xff0c;主要通上⽔就可以⾃动化洒⽔并且可以⾃动的旋转。 ⾃动洗⼿液&#xff0c;免去了⼿动挤压可以⾃动感应出洗⼿液 超市⾃动闸⻔&#xff0c;不需要⼿动的开⻔关⻔ ⽣活中的⾃动化案例有效的减少了⼈⼒的消耗&#xff0c;同时也提⾼了⽣…

C语言程序设计(初识C语言后部分)

代码是一门艺术&#xff0c;键盘是我的画笔。 3.递归和迭代&#xff08;循环就是一种迭代&#xff0c;迭代不仅仅是循环&#xff09; 求n&#xff01; 递归方式&#xff1a; n!---> 1 (n1); n*(n-1)! (n>1) #include <stdio.h> //n!-->递归方式 int fac(in…

Kafka运行机制(一):Kafka集群启动,controller选举,生产消费流程

前置知识 Kafka基本概念https://blog.csdn.net/dxh9231028/article/details/141270920?spm1001.2014.3001.5501 1. Kafka集群启动 Kafka在启动集群中的各个broker时&#xff0c;broker会向controller注册自己&#xff0c;并且从controller节点同步集群元数据。 broker是Kaf…