• LeetCode696. 计数二进制子串


    项目场景:

    坚持一个月了,加油!


    问题描述

    1. 计数二进制子串
      给定一个字符串 s,统计并返回具有相同数量 0 和 1 的非空(连续)子字符串的数量,并且这些子字符串中的所有 0 和所有 1 都是成组连续的。

    重复出现(不同位置)的子串也要统计它们出现的次数。

    示例 1:

    输入:s = “00110011”
    输出:6
    解释:6 个子串满足具有相同数量的连续 1 和 0 :“0011”、“01”、“1100”、“10”、“0011” 和 “01” 。
    注意,一些重复出现的子串(不同位置)要统计它们出现的次数。
    另外,“00110011” 不是有效的子串,因为所有的 0(还有 1 )没有组合在一起。
    示例 2:

    输入:s = “10101”
    输出:4
    解释:有 4 个子串:“10”、“01”、“10”、“01” ,具有相同数量的连续 1 和 0 。

    提示:

    1 <= s.length <= 105
    s[i] 为 ‘0’ 或 ‘1’


    原因分析:

    我们可以将字符串 s 按照 0和 1 的连续段分组,存在 counts 数组中,例如 s = 00111011,可以得到这样的 counts 数组:counts = {2, 3, 1, 2}。

    这里counts 数组中两个相邻的数一定代表的是两种不同的字符。假设 counts 数组中两个相邻的数字为 u 或者 v,它们对应着 u 个 0 和 v 个 1,或者 u 个 1 和 v 个 0。它们能组成的满足条件的子串数目为min{u,v},即一对相邻的数字对答案的贡献。

    我们只要遍历所有相邻的数对,求它们的贡献总和,即可得到答案。
    在这里插入图片描述


    解决方案:

    class Solution {
        public int countBinarySubstrings(String s) {
            List<Integer> counts = new ArrayList<Integer>();
            int ptr = 0, n = s.length();
            while (ptr < n) {
                char c = s.charAt(ptr);
                int count = 0;
                while (ptr < n && s.charAt(ptr) == c) {
                    ++ptr;
                    ++count;
                }
                counts.add(count);
            }
            int ans = 0;
            for (int i = 1; i < counts.size(); ++i) {
                ans += Math.min(counts.get(i), counts.get(i - 1));
            }
            return ans;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
  • 相关阅读:
    PyCharm中环境变量与系统不相通问题
    华为机试 - 最大平分数组
    从0到1学会Git(第三部分):Git的远程仓库链接与操作
    【vue】vue网站设计----模仿小米商城首页
    被迫开始学习Typescript —— class
    metrics server request failed - “403 Forbidden“
    K-means 聚类算法学习笔记
    flink java代码在客户端运行
    Linux哲学思想
    上海亚商投顾:沪指重返3100点 房地产板块掀涨停潮
  • 原文地址:https://blog.csdn.net/weixin_43798721/article/details/126596057