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
    }
}
相关推荐
幸运超级加倍~20 分钟前
软件设计师-上午题-16 算法(4-5分)
笔记·算法
yannan2019031327 分钟前
【算法】(Python)动态规划
python·算法·动态规划
埃菲尔铁塔_CV算法29 分钟前
人工智能图像算法:开启视觉新时代的钥匙
人工智能·算法
EasyCVR29 分钟前
EHOME视频平台EasyCVR视频融合平台使用OBS进行RTMP推流,WebRTC播放出现抖动、卡顿如何解决?
人工智能·算法·ffmpeg·音视频·webrtc·监控视频接入
linsa_pursuer30 分钟前
快乐数算法
算法·leetcode·职场和发展
小芒果_0132 分钟前
P11229 [CSP-J 2024] 小木棍
c++·算法·信息学奥赛
qq_4340859033 分钟前
Day 52 || 739. 每日温度 、 496.下一个更大元素 I 、503.下一个更大元素II
算法
Beau_Will34 分钟前
ZISUOJ 2024算法基础公选课练习一(2)
算法
XuanRanDev36 分钟前
【每日一题】LeetCode - 三数之和
数据结构·算法·leetcode·1024程序员节
gkdpjj38 分钟前
C++优选算法十 哈希表
c++·算法·散列表