华为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)  # 输出均衡子串的最大个数

2024华为OD机试(C卷+D卷)最新题库【超值优惠】Java/Python/C++合集

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

#面经##秋招##校招##春招##华为#
全部评论

相关推荐

3 1 评论
分享
牛客网
牛客企业服务