我正在尝试添加这两个二进制文件。我正在尝试编写一个添加两个二进制数的函数。我试图让它添加一对比特。我不知道如何携带额外的比特。这是我编程的:
但是我的索引超出了范围,我不知道如何携带比特。我一直在想我应该第二次调用函数使用递归来添加位,但我不知道如何实现它。任何人都可以告诉我如何编辑我现有的代码,以便它可以工作。
答案 0 :(得分:0)
def add_binary(s1, s2, carry=0):
if not s1:
if not carry: return s2
else: return '1'*carry + s2
if not s2:
if not carry: return s1
else: return '1'*carry + s1
add = int(s1[-1])+int(s2[-1]) + carry
carry = add and not add%2
return add_binary(s1[:-1], s2[:-1], carry) + str(add%2)
输出:
In [16]: add_binary('10101', '10101')
Out[16]: '101010'
In [17]: add_binary('11', '')
Out[17]: '11'
答案 1 :(得分:0)
def add_binary(s1, s2):
def sub(s1, s2, carry):
if s1 or s2 or carry:
add1 = (int(s1[-1]) if s1 else 0) + (int(s2[-1]) if s2 else 0) + carry
return sub(s1[:-1], s2[:-1], add1//2) + str(add1%2)
else:
return ""
return sub(s1, s2, 0)
编辑更明确的版本:
def add_binary(s1, s2):
def sub(s1, s2, carry):
if s1 != "" or s2 != "" or carry != 0:
if s1 == "":
s1 = "0"
if s2 == "":
s2 = "0"
add1 = int(s1[-1]) + int(s2[-1]) + carry
return sub(s1[:-1], s2[:-1], add1//2) + str(add1%2)
else:
return ""
return sub(s1, s2, 0)
答案 2 :(得分:0)
这是一个非常不同的方法,似乎也符合问题陈述。
digits = {('1','1'):'10',('1','0'):'01',('0','1'):'01',('0','0'):'00'}
def add_ones(d1d2):
return digits[d1d2]
def add_binary(s1, s2):
if not '1' in s1: return s2
if not '1' in s2: return s1
while (len(s1)>len(s2)):
s1 = '0' + s1
while (len(s2)>len(s1)):
s2 = '0' + s2
c = [] #carries
p = ['0'] #places
for d1d2 in zip(s1,s2):
ci, pi = add_ones(d1d2)
c.append(ci)
p.append(pi)
c.append('0')
p = ''.join(p)
c = ''.join(c)
return add_binary(p,c)