计算从 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