码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode——29. 两数相除


    题目(点击链接可以直接查看题目:力扣):

            给定两个整数,被除数 dividend 和除数 divisor。将两数相除,要求不使用乘法、除法和 mod 运算符。

            返回被除数 dividend 除以除数 divisor 得到的商。

            整数除法的结果应当截去(truncate)其小数部分,例如:truncate(8.345) = 8 以及 truncate(-2.7335) = -2

    代码:

    1. class Solution {
    2. public static int add(int a, int b) {
    3. int sum = a;
    4. while (b != 0) {
    5. sum = a ^ b;
    6. b = (a & b) << 1;
    7. a = sum;
    8. }
    9. return sum;
    10. }
    11. public static int negNum(int n) {
    12. return add(~n, 1);
    13. }
    14. public static int minus(int a, int b) {
    15. return add(a, negNum(b));
    16. }
    17. public static int multi(int a, int b) {
    18. int res = 0;
    19. while (b != 0) {
    20. if ((b & 1) != 0) {
    21. res = add(res, a);
    22. }
    23. a <<= 1;
    24. b >>>= 1;
    25. }
    26. return res;
    27. }
    28. public static boolean isNeg(int n) {
    29. return n < 0;
    30. }
    31. public static int div(int a, int b) {
    32. int x = isNeg(a) ? negNum(a) : a;
    33. int y = isNeg(b) ? negNum(b) : b;
    34. int res = 0;
    35. for (int i = 30; i >= 0; i = minus(i, 1)) {
    36. if ((x >> i) >= y) {
    37. res |= (1 << i);
    38. x = minus(x, y << i);
    39. }
    40. }
    41. return isNeg(a) ^ isNeg(b) ? negNum(res) : res;
    42. }
    43. public static int divide(int a, int b) {
    44. if (a == Integer.MIN_VALUE && b == Integer.MIN_VALUE) {
    45. return 1;
    46. } else if (b == Integer.MIN_VALUE) {
    47. return 0;
    48. } else if (a == Integer.MIN_VALUE) {
    49. if (b == negNum(1)) {
    50. return Integer.MAX_VALUE;
    51. } else {
    52. int c = div(add(a, 1), b);
    53. return add(c, div(minus(a, multi(c, b)), b));
    54. }
    55. } else {
    56. return div(a, b);
    57. }
    58. }
    59. }

            注:代码使用位运算实现加减乘除

  • 相关阅读:
    Elasticsearch集群连载-es集群安装
    代码随想录训练营day46, 单词拆分和多重背包
    【深度学习笔记】计算机视觉——FCN(全卷积网络
    树莓派利用OpenCV的图像跟踪、人脸识别等
    Navicat Premium连接Django项目的数据库
    中间件 | Redis - [分布式锁 & 事务]
    shell脚本
    Net Core API +Vue Nginx集成发布
    计算机毕业设计springboot家庭支出网页管理系统668mf源码+系统+程序+lw文档+部署
    多系统架构设计思考
  • 原文地址:https://blog.csdn.net/z1171127310/article/details/126567408
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号