在python中更改后查找最大二进制字符串的程序
假设我们有一个二进制字符串。我们可以多次应用以下每个操作-
如果数字包含子字符串“00”,我们可以用“10”替换它。
如果数字包含子字符串“10”,我们可以用“01”替换它。
然后我们必须找到在任意数量的操作之后我们可以获得的最大二进制(基于其数值)字符串。
因此,如果输入像s="001100",那么输出将是111011,因为我们可以像(00)1100->101(10)0->1010(10)->10(10)01一样传递它们->100(10)1->1(00)011->111011。
示例
让我们看看以下实现以获得更好的理解-
def solve(s):
length = len(s)
zeros = s.count('0')
if zeros < 2:
return s
s = s.lstrip('1')
leading_ones = length - len(s)
leading_ones += zeros - 1
trailing_ones = length - leading_ones - 1
answer_left = '1' * leading_ones
answer_right = '1' * trailing_ones
return ''.join([answer_left, '0', answer_right])
s = "001100"
print(solve(s))输入
"001100"输出结果
111011