最强解析面试题:不用加减乘除做加法「建议收藏!」

Posted 魏小言

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了最强解析面试题:不用加减乘除做加法「建议收藏!」相关的知识,希望对你有一定的参考价值。


最强解析面试题:不用加减乘除做加法「建议收藏!」

手撕算法,是面试中必遇的一道坎,迈过去就是康庄大道,不然就是重头再来!拿下这些,你将走向柏油…

文章讲解 “ 不用加减乘除做加法 ” 经典面试题,包含思路及源码!

题目

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

示例1

输入:
1,2
返回值:
3

思路

  • 计算策略确定,不使用四则运算符号「十进制」,可将转化为位计算。
  • 拆解 ” + “ 运算过程为 和 = 分位和 + 进位和,当进位和归零时,计算终止。
    • 例子: 2 + 28 = 20 + 10 = 30
  • 位计算依托于二进制,二进制相加过程即拆解过程,分位和 = 异或、进位和 = 与<<1
    • 例子:2 + 5 = 0010^0101 + 0010&0101<<1 = 0111

编码

package main


/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 * 
 * @param num1 int整型 
 * @param num2 int整型 
 * @return int整型
*/
func Add( num1 int ,  num2 int ) int {
    // write code here
    for num2 != 0{
        tmp := num1
        num1 ^= num2
        num2 = (tmp & num2) << 1
    }
    return num1
}

运行结果

运行时间 在 4ms 内,占用内存在 1347KB 。

运行时间:4ms
超过100.00% 用Go提交的代码
占用内存:1347KB
超过36.86%用Go提交的代码

Q&A

1、针对问题解法,二进制的性质不容易想到啊!

对的,二进制性质实际开发也几乎用不到。
不过话说回来,这边编程题又有什么实际意义呢?99%实际用不到…

2、这个编程题,对开发有什么益处呢?

这道题纯数学类「二进制计算」。
对开发有没有益处?就像妈妈说,吃青菜能长高!细品…

附录

编程项目开发、测试进度科学比例是 “开发周期 = 测试周期”

以上是关于最强解析面试题:不用加减乘除做加法「建议收藏!」的主要内容,如果未能解决你的问题,请参考以下文章

最强解析面试题:替换空格「建议收藏!」

最强解析面试题:替换空格「建议收藏!」

最强解析面试题:矩形覆盖「建议收藏!」

最强解析面试题:矩形覆盖「建议收藏!」

最强解析面试题:从尾到头打印链表「建议收藏!」

最强解析面试题:从尾到头打印链表「建议收藏!」