华为OD 机试真题 - 分割均衡字符串(Python)
题目描述
均衡串定义:字符串只包含两种字符,且两种字符的个数相同。
给定一个均衡字符串,请给出可分割成新的均衡子串的最大个数。
约定字符串中只包含大写的'X"和'Y'两种字符。
输入描述
均衡串:XXYYXY
字符串的长度[2,10000]。给定的字符用均为均衡串。
输出描述
可分割为两个子串:
XXYY
XY
示例1
输入
XXYYXY
输出
2
备注
分割后的子串,是原字符串的连续子串。
题解
本题属于贪心算法题。通过遍历字符串,实时计算字符出现的次数,并在满足条件时立即进行分割。
- 初始化计数器:
- 使用两个计数器
xcnt
和ycnt
分别记录字符'X'和'Y'的出现次数。- 遍历字符串:
- 遍历字符串中的每一个字符,根据字符类型更新相应的计数器。
- 每当两个计数器相等时,说明当前子串是一个均衡子串,此时可以增加均衡子串计数器
ans
的值。- 输出结果:
- 最后,输出均衡子串的最大个数。
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
#面经##秋招##校招##春招##华为#