题解 | #不用加减乘除做加法#

不用加减乘除做加法

https://www.nowcoder.com/practice/59ac416b4b944300b617d4f7f111b215

接上题解,补充递归写法

class Solution:
    def Add(self, num1: int, num2: int) -> int:
        # 本题最大正值2000 =0x7D0。
        # 取12位足够了,来截断更高位。
        board = 0xFFF
        num1, num2 = num1 & board, num2 & board

        if num2 == 0:
            return num1 if num1 <= 0x7D0 else ~(num1 ^ board)
            
        return self.Add((num1 ^ num2), (num1 & num2) << 1)


全部评论

相关推荐

“校招”、“3-5年经验”
飞花断音:小公司招逆向的不要去,基本上都是搞黑灰产违法的东西
点赞 评论 收藏
分享
06-12 16:00
天津大学 Java
牛客30236098...:腾讯坏事做尽,终面挂是最破防的 上次被挂了后我连简历都不刷了
点赞 评论 收藏
分享
05-30 12:03
山西大学 C++
offer来了我跪着...:不是骗子,等到测评那一步就知道为啥这么高工资了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务