博客
关于我
剑指offer之不用加减乘除做加法
阅读量:639 次
发布时间:2019-03-14

本文共 972 字,大约阅读时间需要 3 分钟。

为了求两个整数之和,而不使用+、-、*、/四则运算符,我们可以利用二进制逐位运算的原理。二进制加法中的异或操作(^)可以用来计算每一位的和,而与操作(&)可以用来计算进位。具体来说,逐位相加的结果是异或操作的结果,进位是与操作后的结果左移一位。重复这个过程,直到没有进位为止,最终的数值即为两个整数的和。

例如,对于两个数5(二进制0101)和6(二进制0110),逐位运算如下:

  • 逐位相加,进行异或操作和与操作:

    • bit1:1 ^ 0 = 1,进位bit carry1:0 ^ 1 = 0。
    • bit2:0 ^ 1 = 1,进位bit carry2:1 & 1 = 1,左移后变为10。
    • bit3:1 ^ 1 = 0,进位bit carry3:没有进位。
    • bit4:0 ^ 0 = 0,进位bit carry4:没有进位。
  • 组合结果,得到二进制1011,即十进制11。

  • 基于上述逻辑,我们可以编写如下函数:

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

    思路:利用二进制逐位运算,通过异或操作求出每位的和,通过与操作和左移得到进位,最终组合得到结果。

    代码实现:

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

    函数逐步解释如下:

  • 循环条件:当num2不等于0时,继续执行循环。
  • sum = num1 ^ num2:计算当前位的和。
  • 进位计算:使用按位与(&)和左移(<< 1)来计算进位,并将进位加入num2,继续处理。
  • 更新sum(num1):将当前位的sum存入num1,继续下一位的处理。
  • 返回结果:当没有进位时(num2 == 0),返回最终结果。
  • 该方法高效且简洁,有效避免了使用四则运算符,同时保证了函数的性能。

    转载地址:http://vogoz.baihongyu.com/

    你可能感兴趣的文章
    OAuth 及 移动端鉴权调研
    查看>>
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>