题目:
给定两个二进制字符串,返回他们的和(用二进制表示)。
输入为非空字符串且只包含数字 1
和 0
。
示例 1:
输入: a = "11", b = "1" 输出: "100"
示例 2:
输入: a = "1010", b = "1011" 输出: "10101"
自己写的通不过测试,看看别人的解答:
转化为10进制相加再转化回去。
class Solution(object):
def addBinary(self, a, b):
"""
:type a: str
:type b: str
:rtype: str
"""
a1 = int(a, 2)
b1 = int(b, 2)
c = a1 + b1
c1 = bin(c)[2:]
return c1
int()函数将一个数字或base类型的字符串转换成整数。
int(x=0)
int(x, base=10),base缺省值为10,也就是说不指定base的值时,函数将x按十进制处理。
注:
1. x 可以是数字或字符串,但是base被赋值后 x 只能是字符串
2. x 作为字符串时必须是 base 类型,也就是说 x 变成数字时必须能用 base 进制表示
bin()函数返回一个整型int或者长整数long int的二进制表示。
bin()运算返回的是二进制。所以前两位是二进制的标志,需要[2:]去除。