【携程秋招】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);

    }
}
相关推荐
橘颂TA38 分钟前
【Linux】自旋锁
linux·开发语言·数据库·c++
一诺加油鸭42 分钟前
若依后端系统集成 Swagger 接口文档功能
java·开发语言
ECT-OS-JiuHuaShan43 分钟前
功夫不负匠心人,渡劫代谢舞沧桑
android·开发语言·人工智能·算法·机器学习·kotlin·拓扑学
knight_9___43 分钟前
LLM工具调用面试篇1
开发语言·人工智能·python·面试·agent
一脸dio样7541 小时前
第5章 保护模式进阶,向内核迈进
linux·开发语言
云烟成雨TD1 小时前
Spring AI Alibaba 1.x 系列【40】多智能体核心模式 - 智能体作为工具(Agent as Tool)
java·人工智能·spring
小叮当⇔1 小时前
M4A 转 MP3 桌面转换器(PyQt5 + FFmpeg)
开发语言·qt·ffmpeg
测试员周周1 小时前
【踩坑系列3】飞书机器人集体“失联“?3 个 Gateway 进程让我差点崩溃!一个测试老兵的排查实录
java·python
aq55356001 小时前
Laravel9.x新特性全解析
java·开发语言·数据库
亦暖筑序1 小时前
AI 客服系统升级实战:多 Agent 路由 + 多轮记忆 + 敏感词过滤
java·后端