华为OD 机试真题 - 分割均衡字符串(Python)

alt

题目描述

均衡串定义:字符串只包含两种字符,且两种字符的个数相同。

给定一个均衡字符串,请给出可分割成新的均衡子串的最大个数。

约定字符串中只包含大写的’X"和’Y’两种字符。

输入描述

均衡串:XXYYXY

字符串的长度[2,10000]。给定的字符用均为均衡串。

输出描述

可分割为两个子串:

XXYY

XY

示例1

输入
XXYYXY

输出
2

备注
分割后的子串,是原字符串的连续子串。

题解

本题属于贪心算法题。通过遍历字符串,实时计算字符出现的次数,并在满足条件时立即进行分割。

  1. 初始化计数器
    • 使用两个计数器xcntycnt分别记录字符’X’和’Y’的出现次数。
  2. 遍历字符串
    • 遍历字符串中的每一个字符,根据字符类型更新相应的计数器。
    • 每当两个计数器相等时,说明当前子串是一个均衡子串,此时可以增加均衡子串计数器ans的值。
  3. 输出结果
    • 最后,输出均衡子串的最大个数。

Python

s = input()  # 读取输入的均衡字符串

ans = 0  # 初始化结果计数器
xcnt, ycnt = 0, 0  # 初始化字符'X'和'Y'的计数器

# 遍历字符串中的每一个字符
for ch in s:
    if ch == 'X':
        xcnt += 1  # 如果字符是'X',增加'X'的计数
    else:
        ycnt += 1  # 如果字符是'Y',增加'Y'的计数

    if xcnt == ycnt:
        ans += 1  # 当'X'和'Y'的计数相等时,增加均衡子串计数

print(ans)  # 输出均衡子串的最大个数

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏4

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-17 10:24:01       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-17 10:24:01       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-17 10:24:01       58 阅读
  4. Python语言-面向对象

    2024-07-17 10:24:01       69 阅读

热门阅读

  1. 初识Flutter问答&学习步骤

    2024-07-17 10:24:01       21 阅读
  2. golang mux组件兼容转移url

    2024-07-17 10:24:01       21 阅读
  3. 用户excel对CAN进行图形化展示

    2024-07-17 10:24:01       23 阅读
  4. SpringBoot如何使用Kafka来优化接口请求的并发

    2024-07-17 10:24:01       25 阅读
  5. 力扣---46.全排列

    2024-07-17 10:24:01       24 阅读
  6. PFA、PEEK和PP的材质、特点及用途

    2024-07-17 10:24:01       23 阅读
  7. 2024.07.16 oracle函数练习

    2024-07-17 10:24:01       30 阅读
  8. 第一章 Typescript小白快速入门

    2024-07-17 10:24:01       19 阅读
  9. webpack生产环境下的配置

    2024-07-17 10:24:01       26 阅读
  10. Matlab学习笔记01 - 基本数据类型

    2024-07-17 10:24:01       27 阅读
  11. spring-boot2.x整合Kafka步骤

    2024-07-17 10:24:01       19 阅读
  12. 武汉大学学报哲学社会科学版

    2024-07-17 10:24:01       22 阅读