class Calculate:
def ——init——(self,number1,number2) # 接收兩個(gè)參數(shù)
self.number1 = number1
self.number2 = number2
def he(self):
print("和是 : %d " % (self.number1 + self.number2)) # 進(jìn)行格式化輸出
def cha(self):
print("差是 : %d " % (self.number1 - self.number2))
result = Calculate(5,5) # 傳遞兩個(gè)參數(shù)
result.he()
result.cha() # 調(diào)用函數(shù)進(jìn)行求值
'''
寫一個(gè)函數(shù),求兩個(gè)整數(shù)之和,要求在函數(shù)體內(nèi)不得使用+、-、*、/四則運(yùn)算符號(hào)。
'''
# 利用異或以及與進(jìn)位求解
# 不能一個(gè)正數(shù)一個(gè)負(fù)數(shù)
# 可能是python的的整型可以無限大的原因, 導(dǎo)致正數(shù)和負(fù)數(shù)的異或操作不斷變成更小的負(fù)數(shù)而不會(huì)溢出
# # 使用Swift嘗試了一下, 還是可以求得正數(shù)和負(fù)數(shù)的位操作相加運(yùn)算的
# # -*- coding:utf-8 -*-
# class Solution:
# def Add(self, num1, num2):
# while num2:
# sum = num1 ^ num2
# carry = (num1 num2) 1
# num1 = sum
# num2 = carry
# return num1
# s = Solution()
# print(s.Add(4, 2))
# -*- coding:utf-8 -*-
# 通過每次對(duì)num1進(jìn)行與操作保證是一個(gè)32位的整形
# 因此最后我們可以判斷符號(hào)位是否為1做處理
class Solution:
def Add(self, num1, num2):
# write code here
while num2 != 0:
temp = num1 ^ num2
num2 = (num1 num2) 1
num1 = temp 0xFFFFFFFF
# return num1 if num1 >> 31 == 0 else num1 - 4294967296 方法一
return num1 if num1 = 0x7FFFFFFF else ~(num1 ^ 0xFFFFFFFF)
if __name__ == "__main__":
s = Solution()
print(s.Add(4, 2))
# print(countOne(7))
# print(countOne(8))