码迷,mamicode.com
首页 > 其他好文 > 详细

二进制运算使用

时间:2020-05-18 10:44:02      阅读:78      评论:0      收藏:0      [点我收藏+]

标签:nbsp   coder   pre   mat   col   参考   min   return   来源   

问题:

  写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。

 

分析:

  (1)二进制异或将得到他们的非进位部分。

  (2)二进制相与并左移一位,等效于进位。

  (3)重复上述步骤:知道进位为0.

code:

public int Add(int num1,int num2) {
        //return Math.addExact(num1, num2);
        while(num2!=0) {
            int temp = (num1^num2);
            num2 = (num1&num2)<<1;
            num1 = temp;
        }
        return num1;
        
    }
    

参考:

链接:https://www.nowcoder.com/questionTerminal/59ac416b4b944300b617d4f7f111b215?f=discussion
来源:牛客网

public class Solution {
    public int Add(int num1,int num2) {
        while (num2!=0) {
            int temp = num1^num2;
            num2 = (num1&num2)<<1;
            num1 = temp;
        }
        return num1;
    }
}

 

二进制运算使用

标签:nbsp   coder   pre   mat   col   参考   min   return   来源   

原文地址:https://www.cnblogs.com/dream-flying/p/12909133.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!