題目
自己編寫函數:利用map和reduce編寫一個str2float函數,把字符串’123.456’轉換成浮點數123.456:
題目來源——致敬廖雪峰
解決過程
初步的解決方法
def str2float(s):
def char2num(s):
return {'0':0,'1':1,'2':2,'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9}[s]
#這事實上是一個字典
index_point=s.find('.')
if index_point==-1:
daichu=1
else:
daichu=0.1**(len(s)-1-index_point)
s=s[0:index_point]+s[index_point+1:]#這里是除去小數點
from functools import reduce
result1=reduce(lambda x,y:x*10+y,map(char2num,s))
return result1*daichu
這里用到字符串的find()函數進行模式匹配。
這個看起來是沒有問題的可是python3.0里面0.1的三次方是:
>>> 0.1**3
0.0010000000000000002
所以這樣不行,那么我們就是用除法
改用除法
def str2float(s):
def char2num(s):
return {'0':0,'1':1,'2':2,'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9}[s]
#這事實上是一個字典
index_point=s.find('.')
if index_point==-1:
daichu=1
else:
daichu=10**(len(s)-1-index_point)
s=s[0:index_point]+s[index_point+1:]#這里是除去小數點
from functools import reduce
result1=reduce(lambda x,y:x*10+y,map(char2num,s))
return result1/daichu
這樣就能得到正確的結果了。
可是這里我們使用find()函數還要用切片生成新的字符串,這里能夠用split()函數
def str2float(s):
def char2num(s):
return {'0':0,'1':1,'2':2,'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9}[s]
#這事實上是一個字典
strs,index_point=s.split('.'),len(s.split('.')[1])
daichu=10**index_point
s=strs[0]+strs[1]#這里是除去小數點
from functools import reduce
result1=reduce(lambda x,y:x*10+y,map(char2num,s))
return result1/daichu
這里的char2num事實上是全然不必要定義的,由於已經有int(str)這樣的構造函數了
改用int函數
def str2float(s):
strs,index_point=s.split('.'),len(s.split('.')[1])
daichu=10**index_point
s=strs[0]+strs[1]#這里是除去小數點
from functools import reduce
result1=reduce(lambda x,y:x*10+y,map(int,s))
return result1/daichu
當然我們也能夠把小數部分倒着計算,這樣代碼會更簡短。花更短的時間思考就能寫更短的代碼
小數部分倒着算
from functools import reduce
def str2float(s):
a = s.split('.')
return reduce(lambda x, y: x*10+y, map(int, a[0]))\
+ reduce(lambda x, y: x/10+y, map(int, a[1][::-1])) / 10
a[1][::-1])這種方法非常巧妙。能夠用於把字符串倒序輸出。比如
a[::-1]
也就是設置步長為1從右往左取,第二個參數表示右邊開始取的位置,第一個參數表示第一個不用取的位置。
