(其他) 剑指 Offer 64. 求1+2+…+n ——【Leetcode每日一题】

❓ 剑指 Offer 64. 求1+2+...+n

难度:中等

1+2+...+n ,要求不能使用乘除法forwhileifelseswitchcase 等关键字及 条件判断语句(A?B:C)。

示例 1:

输入: n = 3

输出: 6

示例 2:

输入: n = 9

输出: 45

限制

  • 1 <= n <= 10000

💡思路:

使用递归解法最重要的是指定返回条件,但是本题无法直接使用 if 语句来指定返回条件。

条件与 && 具有短路原则,即在第一个条件语句为 false 的情况下不会去执行第二个条件语句

  • 利用这一特性,将递归的返回 条件 取非 然后作为 &&第一个条件语句 ,递归的主体转换为 第二个条件语句
  • 那么当递归的返回条件true 的情况下就不会执行递归的主体部分,递归返回。
    • 本题的递归返回条件n <= 0,取非后就是 n > 0
    • 递归的主体部分sum += Sum_Solution(n - 1),转换为条件语句后就是 (sum += Sum_Solution(n - 1)) > 0

注意:Java 中,为构成语句,需加一个辅助布尔量 xxx ,否则会报错;

🍁代码:(C++、Java)

C++

cpp 复制代码
class Solution {
public:
    int sumNums(int n) {
        n && (n += sumNums(n - 1));
        return n;
    }
};

Java

java 复制代码
class Solution {
    public int sumNums(int n) {
        boolean flag = (n > 0) && ((n += sumNums(n - 1)) > 0);
        return n;
    }
}

🚀 运行结果:

🕔 复杂度分析:

  • 时间复杂度 : O ( n ) O(n) O(n),递归函数递归 n 次,每次递归中计算时间复杂度为 O ( 1 ) O(1) O(1),因此总时间复杂度为 O ( n ) O(n) O(n)。
  • 空间复杂度 : O ( n ) O(n) O(n),递归函数的空间复杂度取决于递归调用栈的深度,这里递归函数调用栈深度为 O ( n ) O(n) O(n),因此空间复杂度为 O ( n ) O(n) O(n)。

题目来源:力扣。

放弃一件事很容易,每天能坚持一件事一定很酷,一起每日一题吧!
关注我LeetCode主页 / CSDN---力扣专栏,每日更新!

注: 如有不足,欢迎指正!

相关推荐
yi.Ist22 分钟前
数据结构 —— 键值对 map
数据结构·算法
s1533525 分钟前
数据结构-顺序表-猜数字
数据结构·算法·leetcode
Coding小公仔27 分钟前
LeetCode 8. 字符串转换整数 (atoi)
算法·leetcode·职场和发展
GEEK零零七33 分钟前
Leetcode 393. UTF-8 编码验证
算法·leetcode·职场和发展·二进制运算
DoraBigHead2 小时前
小哆啦解题记——异位词界的社交网络
算法
木头左3 小时前
逻辑回归的Python实现与优化
python·算法·逻辑回归
lifallen7 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
web_Hsir9 小时前
vue3.2 前端动态分页算法
前端·算法
地平线开发者11 小时前
征程 6M 部署 Omnidet 感知模型
算法·自动驾驶
秋说12 小时前
【PTA数据结构 | C语言版】线性表循环右移
c语言·数据结构·算法