我需要编写一个程序,从带有 def 的数字列表中计算累积和,但只能使用递归。我做到了,但现在我需要在不使用方法的情况下编写相同的程序sum
,但到目前为止还没有成功。任何的想法?
我的代码:
def rec_cumsum(numbers):
''' Input: numbers - a list of numbers,
Output: a list of cumulative sums of the numbers'''
if len(numbers)==0: return numbers
return rec_cumsum(numbers[:-1])+ [sum(numbers)]
输入:
1 [1,2,3]
2 [2, 2, 2, 3]
输出:
1 [1,3,6]
2 [2, 4, 6, 9]
我的代码没有sum
:
def rec_cumsum(numbers):
''' Input: numbers - a list of numbers,
Output: a list of cumulative sums of the numbers'''
if len(numbers) == 0: return numbers
my_list=[]
rec_cumsum(my_list + numbers)
my_list[0]=numbers[0]
rec_cumsum(my_list)
temp_sum=my_list[0]+numbers[-1]
my_list[0]=temp_sum
return my_list