python实现reduce():
def re(bin_func,seq,init=None):
lseq=list(seq)
if init is None:
res=lseq.pop(0)
else:
res=init
for item in lseq:
res=bin_func(res,item)
return res
第一次看这个代码的时候,认为当init=None时,将seq序列中的第一项值加了两次,其原因是:对pop()这个内置函数理解错误,误以为pop(0)函数只是将列表的第一项取出,其实是删除列表的第一项并返回该值;后来自己写该函数去验证,将res=bin_func(res,item)写成了bin_func(res,item),答案死活不对,耽搁了好一会儿,自己太粗心大意了!
另附pop()函数的使用(转自http://www.runoob.com/python/att-list-pop.html):
描述
pop() 函数用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。
语法
pop()方法语法:
list.pop(obj=list[-1])
参数
obj – 可选参数,要移除列表元素的对象。
返回值
该方法返回从列表中移除的元素对象。
实例
以下实例展示了 pop()函数的使用方法:
aList = [123, ‘xyz’, ‘zara’, ‘abc’];
print “A List : “, aList.pop();
print “B List : “, aList.pop(2);
以上实例输出结果如下:
A List : abc
B List : zara