• 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. }

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

  • 相关阅读:
    聊聊ElasticeSearch并发写的乐观锁机制
    前端禁止微信自定义字体大小(WebView调整H5字体大小)
    Numpy中的四个小技巧
    使用C语言实现静态顺序表
    Google-CTF-2016-Stego.pcap数据包解析
    MYSQL增删改查
    php框架详解-symfony框架
    mysql日志管理
    算法通关村第二关终于学会链表反转了
    数据操作(CUD)
  • 原文地址:https://blog.csdn.net/z1171127310/article/details/126567408