1 回答

TA貢獻(xiàn)24條經(jīng)驗 獲得超7個贊
map(func,seq1[,seq2...])?:將函數(shù)func作用于給定序列的每個元素,并用一個列表來提供返回值;如果func為None,func表現(xiàn)為身份函數(shù),返回一個含有每個序列中元素集合的n個元組的列表。
reduce(func,seq[,init])?:func為二元函數(shù),將func作用于seq序列的元素,每次攜帶一對(先前的結(jié)果以及下一個序列的元素),連續(xù)的將現(xiàn)有的結(jié)果和下一個值作用在獲得的隨后的結(jié)果上,最后減少我們的序列為一個單一的返回值:如果初始值init給定,第一個比較會是init和第一個序列元素而不是序列的頭兩個元素。
eg:
from functools import reduce??
def str2float(s):
?s = s.split('.') #以小數(shù)點(diǎn)為分隔符,把字符串分為兩部分?
?def f1(x,y): #函數(shù)1,小數(shù)點(diǎn)之前的數(shù)用這個函數(shù)處理
??return x * 10 + y?
?def f2(x,y): #函數(shù)2,小數(shù)點(diǎn)之后的數(shù)用這個函數(shù)處理
??return x / 10 + y?
?def str2num(str): #函數(shù)3,用于把字符串'123'逐個變?yōu)閿?shù)字
?return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[str]
?return reduce(f1,map(str2num,s[0])) + reduce(f2,list(map(str2num,s[1]))[::-1])/10
??#最后一部是這個解法的精髓
?#小數(shù)點(diǎn)前的數(shù)'123',用 x * 10 + y 正常求和就能得出123,小數(shù)點(diǎn)之后的數(shù)'456'要怎樣才能得出0.456呢?
?#首先把字符串'456'用list(map(str2num,s[1]))轉(zhuǎn)成一個列表[4,5,6]
?#然后用[::-1]切片的方式從后往前取,列表變?yōu)閇6,5,4]
?#然后把[6,5,4]利用reduce函數(shù)放到f2函數(shù)中計算,( 6 / 10 + 5) / 10 + 4 = 4.56,得出結(jié)果4.56
?#再除以一個10,得出0.456,到此成功把字符串'456'變成了浮點(diǎn)數(shù)0.456
?#把前后結(jié)果加起來,就得到了最終解,成功把字符串'123.456'變成了浮點(diǎn)數(shù)123.456
添加回答
舉報