【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},即一对相邻的数字对答案的贡献。
  • 我们只要遍历所有相邻的数对,求它们的贡献总和,即可得到答案。

代码

cpp 复制代码
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;
    }
};
相关推荐
2301_764441336 小时前
LISA时空跃迁分析,地理时空分析
数据结构·python·算法
东北洗浴王子讲AI6 小时前
GPT-5.4辅助算法设计与优化:从理论到实践的系统方法
人工智能·gpt·算法·chatgpt
Billlly6 小时前
ABC 453 个人题解
算法·题解·atcoder
玉树临风ives6 小时前
atcoder ABC 452 题解
数据结构·算法
feifeigo1237 小时前
基于马尔可夫随机场模型的SAR图像变化检测源码实现
算法
fengfuyao9857 小时前
基于STM32的4轴步进电机加减速控制工程源码(梯形加减速算法)
网络·stm32·算法
无敌昊哥战神8 小时前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜8 小时前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展
Proxy_ZZ09 小时前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光9 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生