欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

剑指Offer-46.求1+2+3+...+n

程序员文章站 2022-03-05 13:29:36
...

题目描述

求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。

思路

最直接的想法就是递归计算,但是因为题目限制,递归的终止条件就不太好找了

比较聪明的一个做法是可以用短路运算(&&)来终止递归!

public class Solution {
    public int Sum_Solution(int n) {
        int sum = n;
        boolean res = (n > 0) && ((sum += Sum_Solution(n - 1)) > 0);
        return sum;
    }
}