美文网首页
Java日记2018-06-14

Java日记2018-06-14

作者: hayes0420 | 来源:发表于2018-06-14 06:15 被阅读0次
  1. 求 1+2+3+...+n

正常的带if的实现是这样

public static int sumSolu(int n){
        if(n<=0) return 0;
        int sum=n;
        sum+=sumSolu(n-1);
        return sum;
    }

一旦不需要if,就要利用&&的特点,第一个条件语句为 false 的情况下不会去执行第二个条件语句

public int Sum_Solution(int n) {
    int sum = n;
    boolean b = (n > 0) && ((sum += Sum_Solution(n - 1)) > 0);
    return sum;
}
  1. 不用加减乘除做加法
    a ^ b 表示没有考虑进位的情况下两数的和,(a & b) << 1 就是进位。

递归会终止的原因是 (a & b) << 1 最右边会多一个 0,那么继续递归,进位最右边的 0 会慢慢增多,最后进位会变为 0,递归终止

public int Add(int num1, int num2) {
    return num2 == 0 ? num1 : Add(num1 ^ num2, (num1 & num2) << 1);
}

下一步,每天复习一个旧的,学习一个新的leetcode,

相关文章

网友评论

      本文标题:Java日记2018-06-14

      本文链接:https://www.haomeiwen.com/subject/ozkeeftx.html