App下載

python怎么使用二進制運算求兩個數(shù)的和與差?

猿友 2021-07-20 16:04:10 瀏覽數(shù) (3863)
反饋

在學習一些計算機基礎(chǔ)知識的時候我們會學習到位運算。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ù)一個負數(shù)
# 可能是python的的整型可以無限大的原因, 導致正數(shù)和負數(shù)的異或操作不斷變成更小的負數(shù)而不會溢出
# # 使用Swift嘗試了一下, 還是可以求得正數(shù)和負數(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。




0 人點贊