leetcode 696. 计数二进制子串
- 题目描述
- 解题思路
- 执行结果
题目描述
-
计数二进制子串 给定一个字符串 s,统计并返回具有相同数量 0 和 1 的非空(连续)子字符串的数量,并且这些子字符串中的所有 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 <= s.length <= 105 s[i] 为 '0' 或 '1'
解题思路
法1
分组计算\
-
将字符串不同区域的0,1进行分组化(001101010)-->(2,2,1,1,1,1,1) -
计算数量,2,
-
2间有两个0011与01, -
2,1.间有一个(取小的) -
1,1间有一个 一共算来有七个 -
时间复杂度(O(n)) -
空间复杂度(O(n))
执行结果
法1
func countBinarySubstrings(s string) int {
var ans, lastCount, curCount int
for i := 0; i < len(s); {
curCount = 1
for j := i + 1; j < len(s) && s[j] == s[i]; j++ {
curCount++
}
ans += min(lastCount, curCount)
lastCount = curCount
i += curCount
}
return ans
}
func min(a, b int) int {//取小的数
if a < b {
return a
}
return b
}
优化
本文由 mdnice 多平台发布