leetcode每日一题:判断一个括号字符串是否有效

题目
一个括号字符串是只由 '(' 和 ')' 组成的 非空 字符串。如果一个字符串满足下面 任意 一个条件,那么它就是有效的:
- 字符串为
(). - 它可以表示为
AB(A与B连接),其中A和B都是有效括号字符串。 - 它可以表示为
(A),其中A是一个有效括号字符串。
给你一个括号字符串 s 和一个字符串 locked ,两者长度都为 n 。locked 是一个二进制字符串,只包含 '0' 和 '1' 。对于 locked 中 每一个 下标 i :
- 如果
locked[i]是'1',你 不能 改变s[i]。 - 如果
locked[i]是'0',你 可以 将s[i]变为'('或者')'。
如果你可以将 s 变为有效括号字符串,请你返回 true ,否则返回 false 。
示例 1:

输入:s = "))()))", locked = "010100"
输出:true
解释:locked[1] == '1' 和 locked[3] == '1' ,所以我们无法改变 s[1] 或者 s[3] 。
我们可以将 s[0] 和 s[4] 变为 '(' ,不改变 s[2] 和 s[5] ,使 s 变为有效字符串。
示例 2:
输入:s = "()()", locked = "0000"
输出:true
解释:我们不需要做任何改变,因为 s 已经是有效字符串了。
示例 3:
输入:s = ")", locked = "0"
输出:false
解释:locked 允许改变 s[0] 。
但无论将 s[0] 变为 '(' 或者 ')' 都无法使 s 变为有效字符串。
示例 4:
输入:s = "(((())(((())", locked = "111111010111"
输出:true
解释:locked 允许我们改变 s[6] 和 s[8]。
我们将 s[6] 和 s[8] 改为 ')' 使 s 变为有效字符串。
提示:
n == s.length == locked.length1 <= n <= 105s[i]要么是'('要么是')'。locked[i]要么是'0'要么是'1'。
思路
一看到题目是判断合法括号,就想到了这题好像我会啊,不就是用栈来判断,左括号压栈,右括号出栈,如果栈最后为空,且中间也没有不够用(遇到右括号,但是栈为空导致无元素可以弹出),那么就是合法括号。

如果只有一种括号,这里还可以优化,不需要真正去压栈和出栈,用一个变量,左括号就+1,右括号就-1,直到最后结果为0,且中间不存在任何时候是小于0的情况,就是合法括号。
本题略微有一些变化,求的是是否可以通过改变原始字符串,变成合法括号。一个合法的括号,必然满足如下条件:
- 长度为偶数,其中一半是左括号,一半是右括号
- 任意一个前缀,都满足左括号数量大于等于右括号数量
- 任意一个后缀,都满足右括号数量大于等于左括号数量
只有locked为1的位置,原始括号才不可变,其他位置的原始括号是可变的,即不用管原始括号是什么。具体操作上,我们可以做如下3步校验:
- 长度为偶数,如果为奇数,肯定不是合法的
- 对于任意一个前缀,贪心的认为,任何非locked的位置,都变成左括号的情况下,都满足左括号数量大于等于右括号数量
- 对于任意一个后缀,贪心的认为,任何非locked的位置,都变成右括号的情况下,都满足右号数量大于等于左括号数量
代码

public boolean canBeValid(String s, String locked) {
// 长度为奇数,不可能是合法括号
int n = s.length();
if ((n & 1) == 1) {
return false;
}
char[] chars = s.toCharArray();
char[] lockedChars = locked.toCharArray();
// 任意一个前缀,左括号都大于等于右括号
int left = 0;
for (int i = 0; i < n; i++) {
if (lockedChars[i] == '1' && chars[i] == ')') {
left--;
} else {
left++;
}
if (left < 0) {
return false;
}
}
// 任意一个后缀,右括号都大于等于左括号
int right = 0;
for (int i = n - 1; i >= 0; i--) {
if (lockedChars[i] == '1' && chars[i] == '(') {
right--;
} else {
right++;
}
if (right < 0) {
return false;
}
}
return true;
}
耗时

leetcode每日一题:判断一个括号字符串是否有效的更多相关文章
- 【python】Leetcode每日一题-扰乱字符串
[python]Leetcode每日一题-扰乱字符串 [题目描述] 使用下面描述的算法可以扰乱字符串 s 得到字符串 t : 如果字符串的长度为 1 ,算法停止 如果字符串的长度 > 1 ,执行 ...
- LeetCode 每日一题「判定字符是否唯一」
我是陈皮,一个在互联网 Coding 的 ITer,微信搜索「陈皮的JavaLib」第一时间阅读最新文章,回复[资料],即可获得我精心整理的技术资料,电子书籍,一线大厂面试资料和优秀简历模板. 题目 ...
- 【JavaScript】Leetcode每日一题-平方数之和
[JavaScript]Leetcode每日一题-平方数之和 [题目描述] 给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a2 + b2 = c . 示例1: 输入:c = 5 ...
- 【JavaScript】【dp】Leetcode每日一题-解码方法
[JavaScript]Leetcode每日一题-解码方法 [题目描述] 一条包含字母 A-Z 的消息通过以下映射进行了 编码 : 'A' -> 1 'B' -> 2 ... 'Z' -& ...
- 【JavaScript】【KMP】Leetcode每日一题-实现strStr()
[JavaScript]Leetcode每日一题-实现strStr() [题目描述] 实现 strStr() 函数. 给你两个字符串 haystack 和 needle ,请你在 haystack 字 ...
- [LeetCode每日一题]81. 搜索旋转排序数组 II
[LeetCode每日一题]81. 搜索旋转排序数组 II 问题 已知存在一个按非降序排列的整数数组 nums ,数组中的值不必互不相同. 在传递给函数之前,nums 在预先未知的某个下标 k(0 & ...
- 【python】Leetcode每日一题-存在重复元素3
[python]Leetcode每日一题-存在重复元素3 [题目描述] 给你一个整数数组 nums 和两个整数 k 和 t .请你判断是否存在 两个不同下标 i 和 j,使得 abs(nums[i] ...
- 【python】Leetcode每日一题-最大数
[python]Leetcode每日一题-最大数 [题目描述] 给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数. 注意:输出结果可能非常大,所以你需要返回一个 ...
- 【python】Leetcode每日一题-丑数
[python]Leetcode每日一题-丑数 [题目描述] 给你一个整数 n ,请你判断 n 是否为 丑数 .如果是,返回 true :否则,返回 false . 丑数 就是只包含质因数 2.3 和 ...
- 【python】Leetcode每日一题-最长公共子序列
[python]Leetcode每日一题-最长公共子序列 [题目描述] 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度.如果不存在 公共子序列 ,返回 0 . ...
随机推荐
- 压力测试-jmeter-copy
1. 场景描述 新申请的服务器,要压测下python算法程序最多能执行多少条数据,有几年没用压力测试工具-jmeter了,重新下载了最新版本,记录下,也希望能帮到准备使用jmeter做压测的朋友. 2 ...
- w3cschool-Storm 入门教程
Storm 基础知识 基础知识 Storm 是一个分布式的,可靠的,容错的数据流处理系统.它会把工作任务委托给不同类型的组件,每个组件负责处理一项简单特定的任务.Storm 集群的输入流由一个被称作 ...
- 【译】.NET 升级助手现在支持升级到集中式包管理
原文 | McKenna Barlow 翻译 | 郑子铭 最近,.NET 升级助手引入了一些有用的新功能和一种新的中央包管理 (CPM) 升级类型. .NET 升级助手可帮助您将解决方案升级到较新版本 ...
- 第10章 LINQ to XML
第10章 LINQ to XML 10.1 架构概述--DOM 和 LINQ to XML 的 DOM XML 文档可以用一棵对象树完整的表示,这称为"文档对象模型(document obj ...
- Doris端口列表
实例名称 端口名称 默认端口 通讯方向 说明 BE be_port 9060 FE --> BE BE 上 thrift server 的端口,用于接收来自 FE 的请求 BE webserve ...
- Flink流处理-简单案例-01
一.pom文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="htt ...
- 基于Trae开发的自动表关联查询工具
对于复杂的一些业务,会涉及很多张表,其间有各种各样的关联关系,在开发&测试过程中,随时需要查看这些表中的数据状态,这种情况下需要我们写一些关联查询的SQL或者多条SQL执行来查看结果,个人感觉 ...
- 使用nvm管理node.js版本,方便vue2,vue3开发
在Vue项目开发过程中,我们常常会遇到同时维护Vue2和Vue3项目的情况.由于不同版本的Vue对Node.js 版本的要求有所差异,这就使得Node.js 版本管理成为了一个关键问题.NVM(Nod ...
- 使用Go复刻skiplist核心功能
0.引言 正好做LC每日一题要求实现一个跳表,于是学习了redis的扩展skiplist,并使用Go进行复刻学习.学习参考了文章:Redis内部数据结构详解(6)--skiplist - 铁蕾的个人博 ...
- Docker 服务、镜像、容器简单命令使用
Docker 进程相关命令 启动docker服务: systemctl start docker 查看docker服务状态: systemctl status docker 停止docker服务: ...