在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
热门推荐
10 生日祝福语简短而有深意
11 餐前仪式祝福语简短
12 侄儿生日祝福语简短独特
13 中班入学祝福语简短大全
14 父亲简短结婚祝福语大全
15 对学姐的简短祝福语
16 考试祝福语简短给对象
17 水晶婚夫妻祝福语简短
18 朋友节最简短祝福语