当前位置: 首页 > article >正文

leetcode 696. 计数二进制子串

  • 题目描述
  • 解题思路
  • 执行结果
leetcode 696. 计数二进制子串.


题目描述

  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'

解题思路

法1

分组计算\

  1. 将字符串不同区域的0,1进行分组化(001101010)-->(2,2,1,1,1,1,1)
  2. 计算数量,2,
  • 2间有两个0011与01,
  • 2,1.间有一个(取小的)
  • 1,1间有一个 一共算来有七个
  • 时间复杂度(O(n))
  • 空间复杂度(O(n))

执行结果

法1

func countBinarySubstrings(s string) int {
    var ans, lastCount, curCount int
    for i := 0; i < len(s); {
        curCount = 1
        for j := i + 1; j < len(s) && s[j] == s[i]; j++ {
            curCount++
        }
        ans += min(lastCount, curCount)
        lastCount = curCount
        i += curCount
    }
    return ans
}

func min(a, b int) int {//取小的数
    if a < b {
        return a
    }
    return b
}

优化


本文由 mdnice 多平台发布


http://www.kler.cn/a/14087.html

相关文章:

  • Http常用面试知识总结
  • 打印完全数
  • Verilog阻塞与非阻塞赋值详解
  • 春秋云镜:CVE-2022-25488(SQL报错注入)
  • 【Java】关于物理存储方式有几种方式的一些讨论
  • 【hello Linux】进程程序替换
  • 两大消息爆出,币圈正在响应全球“去美元化”行动
  • python算法中的深度学习算法之前馈神经网络(详解)
  • 制造型企业为何需要MES管理系统,企业怎样选择合适的MES
  • Linux_红帽8学习笔记分享_7(Crontab计划任务+NTP时间同步服务器)
  • 【Python】matplotlib设置图片边缘距离和plt.lengend图例放在图像的外侧
  • 一级结构规范 合集
  • 【分布式搜索引擎02】
  • 【设计模式】23种设计模式之结构型模式
  • Hi3861 硬件 i2c 驱动 oled
  • MCAL知识点(二十二):LIN MCAL驱动配置详解
  • 2023年工商管理在职研究生择校、择专业指南
  • day18_集合
  • 淘宝iOS拍立淘微距能力探索与实现
  • 阿里云ecs服务器挂载oss