64. 求 1+2+…+n


comments: true

difficulty: 中等
edit_url: https://github.com/doocs/leetcode/edit/main/lcof/面试题64. 求1%2B2%2B…%2Bn/README.md

面试题 64. 求 1+2+...+n

题目描述

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

示例 1:

复制代码
输入: n = 3
输出: 6

示例 2:

复制代码
输入: n = 9
输出: 45

限制:

  • 1 <= n <= 10000

解法

方法一

Python3
python 复制代码
class Solution:
    def sumNums(self, n: int) -> int:
    	# n 是 0,所以 0 and (0 + self.sumNums(-1)) 结果是 0
        return n and (n + self.sumNums(n - 1)) 
Java
java 复制代码
class Solution {
    public int sumNums(int n) {
        int s = n;
        boolean t = n > 0 && (s += sumNums(n - 1)) > 0;
        return s;
    }
}
C++
cpp 复制代码
class Solution {
public:
    int sumNums(int n) {
        n && (n += sumNums(n - 1));
        return n;
    }
};
Go
go 复制代码
func sumNums(n int) int {
	s := 0
	var sum func(int) bool
	sum = func(n int) bool {
		s += n
		return n > 0 && sum(n-1)
	}
	sum(n)
	return s
}
TypeScript
ts 复制代码
var sumNums = function (n: number): number {
    return n && n + sumNums(n - 1);
};
Rust
rust 复制代码
impl Solution {
    pub fn sum_nums(mut n: i32) -> i32 {
        n != 0
            && (
                {
                    n += Solution::sum_nums(n - 1);
                },
                true,
            )
                .1;
        n
    }
}
JavaScript
js 复制代码
/**
 * @param {number} n
 * @return {number}
 */
var sumNums = function (n) {
    return (n ** 2 + n) >> 1;
};
C#
cs 复制代码
public class Solution {
    public int result;
    public int SumNums(int n) {
        helper(n);
        return result;
    }

    public bool helper(int n) {
        result += n;
        return n == 0 || helper(n - 1);
    }
}
Swift
swift 复制代码
class Solution {
    func sumNums(_ n: Int) -> Int {
        var s = n
        let _ = n > 0 && { s += sumNums(n - 1); return true }()
        return s
    }
}
相关推荐
AhriProGramming9 分钟前
Flask-SQLAlchemy精读-双语精选文章
python·算法·flask
孤廖23 分钟前
吃透 C++ 栈和队列:stack/queue/priority_queue 用法 + 模拟 + STL 标准实现对比
java·开发语言·数据结构·c++·人工智能·深度学习·算法
BanyeBirth1 小时前
C++动态规划——LIS(最长不下降子序列)
算法·动态规划
小龙报1 小时前
《算法通关指南---C++编程篇(3)》
开发语言·c++·算法·visualstudio·学习方法·visual studio
凤山老林1 小时前
排序算法:详解插入排序
java·开发语言·后端·算法·排序算法
知星小度S2 小时前
算法训练之多源BFS
算法·宽度优先
2201_758875442 小时前
LeetCode:19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
代码不停2 小时前
Java前缀和算法题目练习
java·开发语言·算法
courniche3 小时前
分组密码常见结构简介
算法·密码学
涤生z3 小时前
list.
开发语言·数据结构·c++·学习·算法·list