【LeetCode】696 . 计数二进制子串

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;
    }
};

猜你喜欢

转载自blog.csdn.net/weixin_43894455/article/details/132313495