
题目描述
给你一个字符串 s
,返回 只含 单一字母 的子串个数 。
示例 1:
输入: s = "aaaba"
输出: 8
解释: 只含单一字母的子串分别是 "aaa", "aa", "a", "b"。
"aaa" 出现 1 次。
"aa" 出现 2 次。
"a" 出现 4 次。
"b" 出现 1 次。
所以答案是 1 + 2 + 4 + 1 = 8。
示例 2:
输入: s = "aaaaaaaaaa"
输出: 55
提示:
1 <= s.length <= 1000
s[i]
仅由小写英文字母组成
解法
方法一:双指针
我们可以使用双指针,用指针 \(i\) 指向当前子串的起始位置,指针 \(j\) 向右移动到第一个与 \(s[i]\) 不同的位置,那么 \([i,..j-1]\) 就是以 \(s[i]\) 为唯一字母的子串,长度为 \(j-i\),那么以 \(s[i]\) 为唯一字母的子串的个数就是 \(\frac{(j-i+1)(j-i)}{2}\),累加到答案中。然后令 \(i=j\),继续遍历,直到 \(i\) 超出字符串 \(s\) 的范围。
时间复杂度 \(O(n)\),其中 \(n\) 是字符串 \(s\) 的长度。空间复杂度 \(O(1)\)。
方法二