(其他) 剑指 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---力扣专栏,每日更新!

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

相关推荐
Fanxt_Ja4 小时前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下4 小时前
最终的信号类
开发语言·c++·算法
茉莉玫瑰花茶5 小时前
算法 --- 字符串
算法
博笙困了5 小时前
AcWing学习——差分
c++·算法
NAGNIP5 小时前
认识 Unsloth 框架:大模型高效微调的利器
算法
NAGNIP5 小时前
大模型微调框架之LLaMA Factory
算法
echoarts5 小时前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Python技术极客5 小时前
一款超好用的 Python 交互式可视化工具,强烈推荐~
算法
徐小夕5 小时前
花了一天时间,开源了一套精美且支持复杂操作的表格编辑器tablejs
前端·算法·github
小刘鸭地下城5 小时前
深入浅出链表:从基础概念到核心操作全面解析
算法