程序,查找要删除的最小字符数,以便在Python中将A替换为B
假设我们有一个仅由两个字母A和B组成的字符串s,我们必须找到需要从s中删除的最小字母数,以在所有B出现之前获得所有As出现。
因此,如果输入类似于S=“AABAABB”,则输出将为1,因为我们可以删除最后一个A以获取AABBB
为了解决这个问题,我们将按照以下步骤操作:
a_right:=s中“A”的出现次数
b_left:=0
ans:=a_right
对于每个索引i和s中的字符c,执行
b_left:=b_left+1
a_right:=a_right-1
如果c与“A”相同,则
除此以外,
ans:=ans和a_right+b_left的最小值
返回ans
让我们看下面的实现以更好地理解:
示例
class Solution:
def solve(self, s):
a_right = s.count("A")
b_left = 0
ans = a_right
for i, c in enumerate(s):
if c == "A":
a_right -= 1
else:
b_left += 1
ans = min(ans, a_right + b_left)
return ans
ob = Solution()S = "AABAABB"
print(ob.solve(S))输入值
"AABAABB"
输出结果
1
热门推荐
10 男士送花祝福语大全简短
11 20岁简短生日祝福语
12 给长辈祝福语简短大全
13 春天变冷祝福语简短
14 生日祝福语 简短独特高考
15 送去考试祝福语大全简短
16 分手毕业祝福语简短女生
17 老哥出门祝福语简短语
18 求简短的职场祝福语