在學(xué)習(xí)一些計算機基礎(chǔ)知識的時候我們會學(xué)習(xí)到位運算。python既提供了將十進制數(shù)據(jù)轉(zhuǎn)化為二進制數(shù)據(jù)的方法,又提供了位運算(二進制運算)的方法,今天小編就用python位運算來實現(xiàn)一個二進制運算求兩數(shù)和差的算法。希望各位小伙伴看完后給小編點個贊。
以下是 在 python 中的利用函數(shù)求兩個數(shù)的和與差
class Calculate:
def ——init——(self,number1,number2) # 接收兩個參數(shù)
self.number1 = number1
self.number2 = number2
def he(self):
print("和是 : %d " % (self.number1 + self.number2)) # 進行格式化輸出
def cha(self):
print("差是 : %d " % (self.number1 - self.number2))
result = Calculate(5,5) # 傳遞兩個參數(shù)
result.he()
result.cha() # 調(diào)用函數(shù)進行求值
補充:python_寫一個函數(shù),求兩個整數(shù)之和,要求在函數(shù)體內(nèi)不得使用+、-、*、/四則運算符號。
看代碼吧~
'''
寫一個函數(shù),求兩個整數(shù)之和,要求在函數(shù)體內(nèi)不得使用+、-、*、/四則運算符號。
'''
# 利用異或以及與進位求解
# 不能一個正數(shù)一個負(fù)數(shù)
# 可能是python的的整型可以無限大的原因, 導(dǎo)致正數(shù)和負(fù)數(shù)的異或操作不斷變成更小的負(fù)數(shù)而不會溢出
# # 使用Swift嘗試了一下, 還是可以求得正數(shù)和負(fù)數(shù)的位操作相加運算的
# # -*- 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 -*-
# 通過每次對num1進行與操作保證是一個32位的整形
# 因此最后我們可以判斷符號位是否為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))
以上就是Python二進制運算求兩數(shù)和差的代碼實現(xiàn),希望能給大家一個參考,也希望大家多多支持W3Cschool。