0696. 计数二进制子串
大约 2 分钟
---
0696. 计数二进制子串
- 标签:双指针、字符串
- 难度:简单
题目链接
题目大意
描述:
给定一个字符串 。
要求:
统计并返回具有相同数量 和 的非空(连续)子字符串的数量,并且这些子字符串中的所有 和所有 都是成组连续的。
重复出现(不同位置)的子串也要统计它们出现的次数。
说明:
- 。
- 为
'0'或'1'。
示例:
- 示例 1:
输入:s = "00110011"
输出:6
解释:6 个子串满足具有相同数量的连续 1 和 0 :"0011"、"01"、"1100"、"10"、"0011" 和 "01" 。
注意,一些重复出现的子串(不同位置)要统计它们出现的次数。
另外,"00110011" 不是有效的子串,因为所有的 0(还有 1 )没有组合在一起。- 示例 2:
输入:s = "10101"
输出:4
解释:有 4 个子串:"10"、"01"、"10"、"01" ,具有相同数量的连续 1 和 0 。解题思路
思路 1:双指针
思路 1:算法描述
这道题目要求统计具有相同数量 和 的非空连续子字符串的数量,并且这些子字符串中的所有 和所有 都是成组连续的。
我们可以使用双指针的方法,统计连续的 和 的个数。
具体步骤如下:
- 初始化 (前一组字符的个数)和 (当前组字符的个数)。
- 初始化结果 。
- 从左到右遍历字符串 ,对于每个位置 (从 开始):
- 如果 ,说明当前字符与前一个字符相同,将 加 。
- 否则,说明遇到了新的一组字符,此时可以形成的子字符串数量为 ,将其加到 中,然后更新 ,。
- 遍历结束后,还需要加上最后一组字符可以形成的子字符串数量 。
- 返回 。
思路 1:代码
class Solution:
def countBinarySubstrings(self, s: str) -> int:
prev = 0 # 前一组字符的个数
curr = 1 # 当前组字符的个数
ans = 0 # 结果
# 遍历字符串
for i in range(1, len(s)):
if s[i] == s[i - 1]:
# 当前字符与前一个字符相同
curr += 1
else:
# 遇到新的一组字符
ans += min(prev, curr)
prev = curr
curr = 1
# 加上最后一组字符可以形成的子字符串数量
ans += min(prev, curr)
return ans思路 1:复杂度分析
- 时间复杂度:,其中 是字符串的长度。只需要遍历一次字符串。
- 空间复杂度:。只使用了常数级别的额外空间。