有时在设计算法时我们需要将字母转为二进制然后进行操作。比较简单的方法是将字母转为ASCII码再做与或非的操作:
a = 'qwerty'
b = 'asdfgh'
tmp = []
# 输出两个字符串按位做与操作后的二进制序列
for i in range(len(a)):
tmp.append(bin(ord(a[i]) & ord(b[i])).replace('0b', ''))
res = ''.join(tmp)
print(res)
# 输出两个字符串按位做与操作后形成的新字符串
for i in range(len(a)):
tmp.append(chr(ord(a[i]) & ord(b[i])).replace('0b', ''))
res = ''.join(tmp)
print(res)
如果数据一开始就是二进制形式,那么要逐位运算,注意逻辑运算符& | ~ ^的操作数须为整数,所以要先用int转换。但是注意不能将整个二进制序列直接转为整数,否则数字就变了,比如二进制序列 10010 实际表示18,但直接转为整数就成了一万零一十。
a = '011001'
b = '101011'
res = ''
# 输出两个二进制序列按位与操作后的新二进制序列
for i in range(len(a)):
res += str(int(a[i]) & int(b[i]))
print(res)
# 输出两个二进制序列按位与操作后的二进制序列对应的整数
for i in range(len(a)):
res += str(int(a[i]) & int(b[i]))
print(int(res, base=2))