计算从 Python 中删除子字符串的最大分数的程序
假设我们有一个字符串s和两个值x和y。我们可以任意次数地执行给定的两种类型的操作。
搜索子串“ab”,如果存在,那么我们可以通过删除它来获得x个点。
搜索子串“ba”,如果存在,那么我们可以通过删除它来获得y点。
我们必须找到对s应用上述操作后可以获得的最大点数。
所以,如果输入像s="cbbaacdeabb"x=4y=5,那么输出将是14,因为初始字符串是"cbbaacdeabb",然后删除"cbbaacde(ab)b"得到4,现在字符串是"cbbaacdeb",然后删除“cb(ba)acdeb”以获得更多5,因此当前分数4+5=9,现在字符串为“cbacdeb”,然后再次删除“c(ba)cdeb”,以获得额外的5,因此当前分数为9+5=14,字符串为“ccdeb””,现在没有什么可以删除的了。
示例
让我们看看以下实现以获得更好的理解-
def solve(s, x, y):
a = 'a'
b = 'b'
ans = 0
a_st = 0
b_st = 0
if y > x:
a,b = b,a
x,y = y,x
for c in s:
if c == a:
a_st += 1
elif c == b:
if a_st:
ans += x
a_st -= 1
else: b_st += 1
else:
ans += y * min(a_st, b_st)
a_st = 0
b_st = 0
return ans + y * min(a_st, b_st)
s = "cbbaacdeabb"
x = 4
y = 5
print(solve(s, x, y))输入
"cbbaacdeabb", 4, 5输出结果
14