不用加减乘除做加法

题目描述

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

这道题看起来非常有趣,既然做加法,但却不让使用+、-、*、/四则运算符号,很多同学看了一眼就懵逼了,这可难倒八戒了。

我们来分析一下,如果不让用四则运算符合,那显然就是用递归了。为啥呢?原因很简单,递归程序里可以不需要运算符合,只要有递归结束条件即可。

举个例子,比如2+3=?

2用二进制表示是0010

3用二进制表示是0011

不用四则运算,我们就该想到使用逻辑运算符,与、或、非、异或,同或等。

显然,我们需要用到与、异或

异或相当于不带进位的加法:

1^0=1,

0^1=1,

0^0=0,

1^1=0

也就是:

image.png

与运算符正好我们可以用来求进位:

 

1&0=0,

0&1=0,

0&0=0,

1&1=1  (此时进位)

image.png

num4是两数做与操作后得到的结果左移一位。为啥需要左移一位呢,哈哈,原因很简单,进位嘛,向高位进位,当然要左移啦!

如上面两图所示,num3代表不进位的加法得到的结果,num4是进位得到的值。二者相加,就是最终结果,而题目要求不能使用加法,因此,我们就继续递归啊!(原因是咱们的递归程序就是在做加法操作)

那么最重要的问题来了,递归程序的结束条件是什么呢?

当进位为0时,直接返回num3就可以了!代码如下:

 

int Add(int num1, int num2) 
{     
        if(num2 == 0) 
        { // 进位为0时,返回
            return num1;
        }
        int num3 = num1 ^ num2; // 不考虑进位
        int num4 = (num1 & num2) << 1; // 进位
        return Add(num3, num4); 
}


 

来源:我是码农,转载请保留出处和链接!

本文链接:http://www.54manong.com/?id=1237

'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646208", container: s }); })();

'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646147", container: s }); })();

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

flybirding10011

谢谢支持啊999

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值