二进制求和

给定两个二进制字符串,返回他们的和(用二进制表示)。

输入为非空字符串且只包含数字 1 和 0

示例 1:

输入: a = "11", b = "1"
输出: "100"

示例 2:

输入: a = "1010", b = "1011"
输出: "10101"

思路:

直接将二进制字符串转化成十进制,相加后,再将结果转化成二进制

class Solution:
    def addBinary(self, a, b):
        """
        :type a: str
        :type b: str
        :rtype: str
        """
        return bin(int(a,2)+int(b,2))[2:]
        
        

知识点复习:

int(x, [base])

作用:

将一个数字或base类型的字符串转换成整数。

int(x=0)

扫描二维码关注公众号,回复: 4982369 查看本文章

int(x, base=10),base缺省值为10,也就是说不指定base的值时,函数将x按十进制处理。

注:

1. x 可以是数字或字符串,但是base被赋值后 x 只能是字符串

2. x 作为字符串时必须是 base 类型,也就是说 x 变成数字时必须能用 base 进制表示

进制转化:

int() => 将其他进制转化成十进制

bin() => 将其他进制转化成二进制

oct() => 将其他进制转化成八进制

hex() => 将其他进制转化成十六进制

注意:

bin(),oct(),hex()返回值均为字符串而且会带有0b,0o,0x前缀

猜你喜欢

转载自blog.csdn.net/sunyadong_/article/details/86533853