【携程秋招】230907四、好串数量 <模拟>

【携程秋招】230907四、好串数量

有一个只包含'0'和'1'的字符串,想知道这个字符串有多少个好子串?

一个字符串如果是好串,那么该字符串的所有前缀,'0'的数量严格大于'1'的数量。

输入:

一个只含'0'和'1'的字符串,长度不超过100000。

输出:

一个整数,代表答案。

输入:

java 复制代码
100

输出

java 复制代码
3

说明

java 复制代码
子区间[2,2]、[2,3]、[3,3]组成的子串都是一个好串。

输入:

java 复制代码
10010

输出

java 复制代码
6

说明

java 复制代码
子区间[2,2]、[2,3]、[3,3]、[2,4]、[2,5]、[5,5]组成的子串都是一个好串。

题解

举例说明:

例如0011100

应该为1+2+1+0+0+1+2=7

由等式找规律

java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String str = in.next();

        long curSum = 0;
        long count = 0;
        for (int i = 0; i < str.length(); i++) {
            //是0
            if (str.charAt(i) == '0') {
                curSum++;
            }
            //是1
            else {
                curSum--;
            }

            if (curSum >= 1) {
                count += curSum;
            } else {
                curSum = 0;
            }
        }
        System.out.println(count);

    }
}
相关推荐
有点。21 分钟前
C++(枚举法一练习题)
开发语言·c++·算法
Klong.k27 分钟前
如何避免Bean的线程安全问题
java·开发语言
basketball61630 分钟前
C++ 单例模式完全指南:从饿汉式到现代 C++ 的最佳实践
java·c++·单例模式
接着奏乐接着舞36 分钟前
【无标题】
开发语言·前端·javascript
iiiiyu37 分钟前
集合进阶(Map集合)
java·大数据·开发语言·数据结构·编程语言
小江的记录本1 小时前
【Java基础】核心关键字:final、static、volatile、synchronized、transient(附《思维导图》+《面试高频考点清单》)
java·前端·数据结构·后端·ai·面试·ai编程
tongluowan0071 小时前
Java 内存模型(JMM)- 内存屏障
java·内存模型·内存屏障
月落归舟1 小时前
并发编程之volatile深度解析(二)
java·开发语言·volatile
me8321 小时前
【AI】踩坑LangChain4j集成千问模型:版本适配问题完整解决历程
java·spring·阿里云·ai