用递归函数方法求1+2+…+n if..
时间: 2023-10-24 22:18:13 浏览: 45
如果您使用 Python 可以这样写:
```python
def sum_n(n):
if n == 0:
return 0
else:
return n + sum_n(n-1)
```
这个函数 `sum_n` 会递归调用自己,每次将 `n` 减一直到 `n=0`,然后返回 0。在返回过程中,每层函数都会将自己的 `n` 与上一层函数返回的结果相加,最终得到 1+2+...+n 的结果。
您可以这样调用这个函数:
```python
n = 10
result = sum_n(n)
print(result) # 输出55
```
这个例子中,`n` 的值为 10,函数返回的结果为 55,即 1+2+...+10 的和。
相关问题
自定义递归函数,求1+2+3+.....+n
好的,我可以为您写一个递归函数来求解1+2+3+...+n。代码如下:
```python
def sum_recursive(n):
if n == 1:
return 1
else:
return n + sum_recursive(n-1)
```
这个函数接受一个正整数n作为参数,如果n为1,则直接返回1,否则返回n加上n-1到1的所有整数的和。可以通过递归调用这个函数来实现。
例如,如果您想求解1+2+3+...+10的和,可以这样调用函数:
```python
print(sum_recursive(10))
```
这将输出55,即1+2+3+...+10的和。
用递归的方法求1+2+3+...+n
以下是使用递归方法求1+2+3+...+n的Python代码:
```python
def sum_numbers(n):
if n == 1:
return 1
else:
return n + sum_numbers(n-1)
n = int(input("请输入一个正整数:"))
print("1到{}的和为:{}".format(n, sum_numbers(n)))
```
在这个递归函数中,我们首先判断n是否等于1,如果是,那么返回1;否则,返回n加上n-1到1的和。这个函数会一直递归调用自己,直到n等于1为止。