剑指 Offer -- 不用加减乘除做加法(四十八)

本文介绍了一种不使用加减乘除实现两整数相加的方法。通过递归调用自身函数,利用位操作实现加法运算。此外,还提供了一个通过创建对象数组间接计算加法的创新思路。

不用加减乘除做加法(四十八)

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

代码(已在牛客上 AC)

注意静态变量要在类外初始化; 另外, 注意看注释, 了解为什么 count 初值是 -1. (因为我们调用函数的方法是: Solution().Add(n1, n2), 会产生一个临时的 Solution 对象.

// 通过这道题可以知道牛客在测试代码的时候, 应该是不断调用
// Solution().Add(num1, num2) 得到结果. 因为会不断地
// 产生 Solution() 这个临时对象, 因此, 为了得到正确的结果,
// 需要使用 reset() 函数将 count 重置. count 初始值为 -1
// 是因为 Solution() 这个临时对象也会影响 count.
class Solution {
private:
    static int count;
    void reset() { count = -1; }
public:
    Solution() { count++; }
public:
    int Add(int num1, int num2)
    {    
        int res;
        Solution a[num1], b[num2];
        res = count;
        reset();
        return res;
    }
};

int Solution::count = -1;

http://cuijiahua.com/blog/2018/01/basis_48.html 给出了一种简洁的方法, 但 … 关键是想不到…. 不纠结, 投降输一半, 知道有这回事就行…

class Solution {
public:
    int Add(int num1, int num2)
    {
        return num2 ? Add(num1 ^ num2, (num1 & num2) << 1) : num1;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值