696. 计数二进制子串
Posted hequnwang10
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了696. 计数二进制子串相关的知识,希望对你有一定的参考价值。
一、题目描述
给定一个字符串 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 。
二、解题
将字符串按照0和1分组,存在数组中,然后统计相邻数对的最小值。
class Solution
public int countBinarySubstrings(String s)
//创建一个集合
List<Integer> counts = new ArrayList<>();
int cur = 0,length = s.length();
while(cur < length)
char ch = s.charAt(cur);
int cnt = 0;
while(cur<length && s.charAt(cur) == ch)
cur++;
cnt++;
counts.add(cnt);
//取最小值
int res = 0;
for(int i = 1;i<counts.size();i++)
res += Math.min(counts.get(i),counts.get(i-1));
return res;
class Solution
public int countBinarySubstrings(String s)
char[] arr = s.toCharArray();
int ans = 0;
int pre = 0,cur = 0;
for(int i = 0;i < arr.length;)
cur = 0;
int temp = arr[i];
while(i < arr.length && arr[i] == temp)
++i;
++cur;
ans += Math.min(pre,cur);
pre = cur;
return ans;
以上是关于696. 计数二进制子串的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode 696. 计数二进制子串 [Count Binary Substrings (Easy)]
696. Count Binary Substrings 计数二进制子字符串