696 . 计数二进制子串(简单)
思路
- 我们可以将字符串按照 0 和 1 的连续段分组,存在 count 数组中。例如 00111011 可以得到:count ={2,3,1,2}。
- 这里 count 数组中两个相邻的数一定代表的是两种不同的字符。假设 count 数组中两个相的数字为或者它们对应着u个0和v个1,或者 u个1和v个0,那么它们能组成的满足条件的子数目为
min{u,v}
,即一对相邻的数字对答案的贡献。 - 我们只要遍历所有相邻的数对,求它们的贡献总和,即可得到答案。
代码
class Solution {
public:
int countBinarySubstrings(string s) {
int ans = 0, cur = 1;
vector<int> count;
for(int i = 0; i < s.size()-1; ++i) {
if(s[i] == s[i+1]) {
cur++;
}else {
count.push_back(cur);
cur = 1;
}
}
count.push_back(cur);
for(int i = 0; i < count.size()-1; ++i) {
ans += min(count[i], count[i+1]);
}
return ans;
}
};