剑指 Offer 64. 求1+2+…+n
题目:
求 1+2+…+n ,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。
示例 1:
输入: n = 3
输出: 6
示例 2:
输入: n = 9
输出: 45
解题思路:
本题在简单问题上做了许多限制,我们之前所使用的一些常规的求阶乘的方法无法使用。
原因:平均计算(有乘法运算)、迭代(含有while或者for循环)、递归(用到了if)。
这个时候可以考虑逻辑运算符,本题需要实现 “当 n = 1时终止递归” 的需求,可通过短路效应实现。
代码如下:
/**
* 执行结果:通过
* 执行用时:0 ms, 在所有 Java 提交中击败了100.00%的用户
* 内存消耗:35.5 MB, 在所有 Java 提交中击败了75.75%的用户
* 通过测试用例:35 / 35
*/
class Solution {
public int sumNums(int n) {
boolean x = n > 1 && (n += sumNums(n - 1)) > 0;
return n;
}
}