当前位置: 首页> 文旅> 美景 > 华为OD 机试真题 - 分割均衡字符串(Python)

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

时间:2025/7/9 4:12:38来源:https://blog.csdn.net/user_longling/article/details/140442879 浏览次数:0次

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: