【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;
    }
};
相关推荐
吴可可1231 分钟前
用Teigha修改并保存CAD文件
数据库·算法·c#
灰灰勇闯IT1 小时前
ops-reduce:ReduceMax 与 ReduceMean 的并行优化
算法
水木流年追梦1 小时前
大模型入门-Reward 奖励模型训练
开发语言·python·算法·leetcode·正则表达式
沙威玛_LHE1 小时前
P13376题解
算法
DFT计算杂谈2 小时前
KPROJ编译教程
java·前端·python·算法·conda
重生之我是Java开发战士2 小时前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
吃好睡好便好3 小时前
用if…end…语句计算分段函数
开发语言·人工智能·学习·算法·matlab
灰灰勇闯IT3 小时前
ops-memory:CANN Runtime 的 Tensor 内存管理
算法
叶子Talk3 小时前
OpenAI破解80年数学猜想,AI首次做出原创证明
人工智能·数学·算法·机器学习·ai·openai·ai推理
MhZhou04124 小时前
1.11M参数小模型实现脑瘤分割 CVPR 2026 Findings 开源
算法·计算机视觉·3d·空间计算