在學(xué)習(xí)一些計(jì)算機(jī)基礎(chǔ)知識(shí)的時(shí)候我們會(huì)學(xué)習(xí)到位運(yùn)算。python既提供了將十進(jìn)制數(shù)據(jù)轉(zhuǎn)化為二進(jìn)制數(shù)據(jù)的方法,又提供了位運(yùn)算(二進(jìn)制運(yùn)算)的方法,今天小編就用python位運(yùn)算來(lái)實(shí)現(xiàn)一個(gè)二進(jìn)制運(yùn)算求兩數(shù)和差的算法。希望各位小伙伴看完后給小編點(diǎn)個(gè)贊。
以下是 在 python 中的利用函數(shù)求兩個(gè)數(shù)的和與差
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)行求值
補(bǔ)充:python_寫一個(gè)函數(shù),求兩個(gè)整數(shù)之和,要求在函數(shù)體內(nèi)不得使用+、-、*、/四則運(yùn)算符號(hào)。
看代碼吧~
'''
寫一個(gè)函數(shù),求兩個(gè)整數(shù)之和,要求在函數(shù)體內(nèi)不得使用+、-、*、/四則運(yùn)算符號(hào)。
'''
# 利用異或以及與進(jìn)位求解
# 不能一個(gè)正數(shù)一個(gè)負(fù)數(shù)
# 可能是python的的整型可以無(wú)限大的原因, 導(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 -*-
# 通過(guò)每次對(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))
以上就是Python二進(jìn)制運(yùn)算求兩數(shù)和差的代碼實(shí)現(xiàn),希望能給大家一個(gè)參考,也希望大家多多支持W3Cschool。