对不起,这似乎是一个基本的问题,但我哪儿也找不到。在Python 2中,我想将一个1变量函数应用到它自己的输出中,存储所有步骤的列表,也就是说,如果f(x)返回x*x,然后从2中迭代,我需要
[2, 4, 16, 256, 65536, ...]
理想情况下,我需要传递函数f、第一个输入1和我希望保留的迭代次数。
我想,从某种意义上说,这与reduce相反,与函数式编程中的unfold有些相似。
做这件事的一个天真的方法就是写
out = [2] for x in xrange(5): out.append(f(out[-1]))
什么是一个好的毕达通方式来做这件事?非常感谢。
发布于 2015-02-04 02:36:46
你需要的是一个"生成器“。例如,
def f(x, n):
for _ in range(n):
yield x
x = x * x
l = list(f(2, 5))
print(l) # [2, 4, 16, 256, 65536]或
def f(x):
while True:
yield x
x = x * x
for v in f(2):
if v > 100000:
break
print(v), # 2 4 16 256 65536发布于 2015-02-04 02:51:21
理想情况下,我需要传递函数f、第一个输入1和我希望保留的迭代次数。
下面是一个展开函数,它接受一个函数、一个起始值和一个迭代计数。
def unfold(function, start, iterations):
results = []
for _ in range(iterations):
results.append(start)
start = function(start)
return results您可以按预期使用:
>>> print unfold(lambda x: x*x, 2, 5)
[2, 4, 16, 256, 65536]https://stackoverflow.com/questions/28312401
复制相似问题