1.题目描述
求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。
传送门
2.code(java1.7版本)
public class Solution {
public int Sum_Solution(int n) {
int sum=n;
boolean ans=(n>0)&&((sum+=Sum_Solution(n-1))>0);
return sum;
}
}
3.解题分析
这道题运用递归的思想加上&&运算符的特性,如果左边的为false,则&&运算符右边的便不会执行,这样即可完成正确的递归。