topic
给定一个字符串 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’
answer
class Solution {
public int countBinarySubstrings(String s) {
char[] chars=s.toCharArray();
ArrayList<Integer> arrayList=new ArrayList<>();
int count=1;
for(int i=0;i<chars.length;i++)
{
if(i+1==chars.length)
{
arrayList.add(count);
count=1;
}
else if(chars[i+1]==chars[i])
{
count++;
}
else
{
arrayList.add(count);
count=1;
}
}
int sum=0;
for(int j=0;j<arrayList.size();j++)
{
if(j+1==arrayList.size()) break;
sum+=Math.min(arrayList.get(j),arrayList.get(j+1));
}
return sum;
}
}