696. 计数二进制子串 Krains 2020-08-10 09:42:23 字符串
时间:2022-07-23
本文章向大家介绍696. 计数二进制子串 Krains 2020-08-10 09:42:23 字符串,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
# 题目链接
仔细观察发现,连续0与连续1构成的串中其符合条件的子串的数目等于Min(n,m)Min(n,m)Min(n,m),n、m分别为连续0和1的个数。
对于这样的问题,解法有很多,简单的一种可以用额外的数组存一下连续0和连续1个数,然后然后遍历数组,统计相邻的最小值即可。
若不用额外空间,考虑的细节就多一点,以下给出了两种相似的解法,细节有所不同。
class Solution {
public int countBinarySubstrings(String s) {
int ans = 0;
int i = 0;
// pre表示之前一段连续1或0个数,cur为当前连续0或1的个数
int pre = 0, cur = 0;
while(i < s.length()){
char c = s.charAt(i);
while(i < s.length() && s.charAt(i) == c){
i++;
cur++;
}
ans += Math.min(pre, cur);
pre = cur;
cur = 0;
}
return ans;
}
}
class Solution {
public int countBinarySubstrings(String s) {
int ans = 0;
int pre = 0, cur = 1;
for(int i = 1; i < s.length(); i++){
if(s.charAt(i-1) == s.charAt(i)){
cur++;
}else{
ans += Math.min(pre, cur);
pre = cur;
cur = 1;
}
}
// 加上末尾未统计的
ans += Math.min(pre, cur);
return ans;
}
}
复杂度分析
- 时间复杂度:O(1)O(1)O(1)
- 空间复杂度:O(1)O(1)O(1)
- HDUOJ----The Number Off of FFF
- HDUOJ-------Naive and Silly Muggles
- HDUOJ----A Computer Graphics Problem
- HDUOJ---(4708)Herding
- HDUOJ---(4708)Rotation Lock Puzzle
- HDUOJ---Hamming Distance(4712)
- HDUOJ-----Difference Between Primes
- HDUOJ----(4706)Children's Day
- poj-------Common Subsequence(poj 1458)
- poj----Maximum sum(poj 2479)
- HDUOJ---hello Kiki
- HDUOJ-----X问题
- POJ-----C Looooops
- POJ--Strange Way to Express Integers
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 斐波那契数组-递归和循环实现
- KMP算法 C#实现 字符串查找简单实现
- elasticsearch压力测试工具之ESrally使用说明
- BitMap算法 .net实现 用于去重并且排序,适用于大型权限管理 ,大数据去重排序
- 5.FFMPEG-Qt移植ffmpeg、ffmpeg结构体介绍
- winform总结6=>线程和委托的关系
- winform总结3> 有趣的bat/winform程序完成自己的任务,然后把自己删除
- winform总结2> Action<> ,Action,func<>,委托相关的理解
- winform开发 总结1>winform程序使用线程的必要性,以及正确的使用方式
- Winform 后台将指定的控件集合添加到制定容器中
- C#微信公众平台接入示例代码
- FreeRTOS三种数据结构区别(StreamBuffer,MessageBuffer,Queue)
- Keras & Tensorflow 笔记
- Netty之HTTP协议应用开发
- 超全Python IDE武器库大总结,优缺点一目了然!