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
    }
}
相关推荐
MediaTea4 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z4 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
WBluuue4 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
风筝在晴天搁浅4 小时前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法
MATLAB代码顾问6 小时前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
代码飞天6 小时前
机器学习算法和函数整理——助力快速查阅
人工智能·算法·机器学习
jiushiapwojdap6 小时前
LU分解法求解线性方程组Matlab实现
数据结构·其他·算法·matlab
笨笨饿6 小时前
69_如何给自己手搓一个串口
linux·c语言·网络·单片机·嵌入式硬件·算法·个人开发
纽扣6677 小时前
【算法进阶之路】链表进阶:删除、合并、回文与排序全解析
数据结构·算法·链表
消失的旧时光-19437 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法