寻找最小删除数以在 Python 中平衡字符串的程序
假设我们有一个字符串s,其中只有两个字符's'和't'。我们可以删除s的任意数量的字符来使字符串平衡。我们可以说,当没有一对索引(i,j)使得i 因此,如果输入类似于s="sststtst",那么输出将是2,因为我们可以删除索引2和6处的字符(“sststtst”到“sssttt”),或者删除索引3处的字符和6(“sststtst”到“sstttt”)。 让我们看看以下实现以获得更好的理解-示例
def solve(s):
cum_b = 0
count_a = s.count("s")
ans = float("inf")
for x in s:
if x == "s":
count_a-=1
ans = min(ans,cum_b + count_a)
else:
cum_b+=1
ans = min(ans,cum_b-1 + count_a)
return ans
s = "sststtst"
print(solve(s))
输入
"sststtst"输出结果
2