python计算两数之和_Leetcode练习(Python):第371题:两整数之和:不使用运算符 + 和 - ???????,计算两整数 ???????a 、b ???????之和。...

题目:

两整数之和:不使用运算符 + 和 - ???????,计算两整数 ???????a 、b ???????之和。

示例 1:

输入: a = 1, b = 2

输出: 3

示例 2:

输入: a = -2, b = 3

输出: 1

思路:

汗,使用异或来实现,但是在Python得进行特殊处理。参考了一下别人的思路,https://github.com/Rosevil1874/LeetCode-Solution-Python-Java/tree/master/Python-Solution/371_Sum_of_Two_Integers

程序:

class Solution:

def getSum(self, a: int, b: int) -> int:

MAX = 0x7FFFFFFF # 32bit 最大正整数

MIN = 0x80000000 # 32bit 最小负整数

mask = 0xFFFFFFFF # 掩码:得到一个二进制数最后32位

while b:

# 加法不带进位的结果,进位

a, b = (a ^ b) & mask, ((a & b) << 1) & mask

# a <= MAX: a为正数,直接返回

# a > MAX:a为负数,计算机存储补码,a ^ mask得到a的按位取反,~得到相反数-1。

return a if a < MAX else ~(a ^ mask)

原文:https://www.cnblogs.com/zhuozige/p/13023631.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值