用 Python 中给定字符串中最少交换次数对 1 进行分组的程序
假设我们得到一个包含0和1的二进制字符串input_str。我们的任务是通过交换给定字符串中的1来对0和1进行分组。我们必须执行最少数量的交换操作,并且必须返回该值。要记住的一件事,我们只能交换相邻的值。
因此,如果输入类似于input_str=10110101,那么输出将是4
交换将如下所示-
10110101->01110101->01111001->01111010->01111100
掉期总数:4。
示例
让我们看看以下实现以获得更好的理解-
def solve(input_string):
one = [i for i in range(len(input_string)) if input_string[i] == "1"]
mid = len(one) //2
res = 0
for i in range(len(one)):
res += abs(one[mid] - one[i]) - abs(mid - i)
return 0 if res < 0 else res
print(solve('10110101'))输入
'10110101'输出结果
4
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短