| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 删除无效的括号 -> 正文阅读 |
|
[数据结构与算法]删除无效的括号 |
给你一个由若干括号和字母组成的字符串? 返回所有可能的结果。答案可以按?任意顺序?返回 示例 1: 输入:s = "()())()" 输出:["(())()","()()()"] 方法:广度优先搜索 注意到题目中要求最少删除,这样的描述正是广度优先搜索算法应用的场景,并且题目也要求我们输出所有的结果。我们在进行广度优先搜索时每一轮删除字符串中的 11 个括号,直到出现合法匹配的字符串为止,此时进行轮转的次数即为最少需要删除括号的个数。 我们进行广度优先搜索时,每次保存上一轮搜索的结果,然后对上一轮已经保存的结果中的每一个字符串尝试所有可能的删除一个括号的方法,然后将保存的结果进行下一轮搜索。在保存结果时,我们可以利用哈希表对上一轮生成的结果去重,从而提高效率。 class?Solution?{ ????public?List<String>?removeInvalidParentheses(String?s)?{ ????????List<String>?ans?=?new?ArrayList<String>(); ????????Set<String>?currSet?=?new?HashSet<String>(); ????????currSet.add(s); ????????while?(true)?{ ????????????for?(String?str?:?currSet)?{ ????????????????if?(isValid(str))?{ ????????????????????ans.add(str); ????????????????} ????????????} ????????????if?(ans.size()?>?0)?{ ????????????????return?ans; ????????????} ????????????Set<String>?nextSet?=?new?HashSet<String>(); ????????????for?(String?str?:?currSet)?{ ????????????????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)?==?')')?{ ????????????????????????nextSet.add(str.substring(0,?i)?+?str.substring(i?+?1)); ????????????????????} ????????????????} ????????????} ????????????currSet?=?nextSet; ????????} ????} ????private?boolean?isValid(String?str)?{ ????????char[]?ss?=?str.toCharArray(); ????????int?count?=?0; ????????for?(char?c?:?ss)?{ ????????????if?(c?==?'(')?{ ????????????????count++; ????????????}?else?if?(c?==?')')?{ ????????????????count--; ????????????????if?(count?<?0)?{ ????????????????????return?false; ????????????????} ????????????} ????????} ????????return?count?==?0; ????} ????} |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/8 4:53:35- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |