写代码过程中,不要忘了在开头写from functools import reduce哦
from functools import reduce
def fn(x, y):
return x * 10 + y
def char2num(s):
digits = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
return digits[s]
reduce(fn, map(char2num, '13579'))
注意:char2num这个函数只能用于小于10的数(也就是从0到9)。
在写上述代码的过程中,你可能会有疑问:'13579' 这几个数不是大于10吗 ?
这里需要注意map函数:map()
将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator
返回。
也就是,map函数将char2num这个函数作用在'13579'中的每一个字符,将其转化为数字。
然后reduce函数,把结果继续和序列的下一个元素做累积计算,其效果就是:
reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
在这个练习中就是:
1*10+3=13, 13*10+5=135, 135*10+7=1357,1357*10+9=13579
至此,大功告成!