我的fs[i-1]根據(jù)我的估計,在循環(huán)過程中會產(chǎn)生fs[0],fs[1],fs[2]這三個數(shù),不會超呀??哪位大俠幫忙看看,代碼很短的#?-*-?coding:?utf-8?-*-
def?count():
????fs?=?[]
????for?i?in?range(1,?4):
????????def?f():
????????????return?i*i
????????fs[i-1]=f()
????????#fs.append(f(i))
????return?fs
f1,?f2,?f3?=?count()
print?f1,?f2,?f3
4 回答
已采納

Iamxiaoq
TA貢獻(xiàn)33條經(jīng)驗 獲得超6個贊
題主是不是js寫多了呢?我記得js里的數(shù)值可以直接對數(shù)組任何一個索引賦值。Python的list是不具備這樣的特性的。
l?=?[]?#?len(l)==0?l的長度為0,里面不存在任何元素,此時若l[0]會引發(fā)索引越界異常,這個應(yīng)該不難理解 l[0]?=?0?#?這也會引發(fā)越界異常,因為l[0]是不存在的,不能對其進(jìn)行賦值,Python不像js那樣若不存在就給你創(chuàng)建,而是拋出異常 l.append(0)?#?ok


蘆薈酸奶
TA貢獻(xiàn)4條經(jīng)驗 獲得超0個贊
count?=?[i*i?for?i?in?range(1,4)] f1,f2,f3?=count print?f1,f2,f3
這樣可讀性更好

孤獨(dú)的小豬
TA貢獻(xiàn)232條經(jīng)驗 獲得超302個贊
正確代碼應(yīng)該是 def?count(): ????fs?=?[] ????for?i?in?range(1,?4): ????????def?f(j): ????????????def?g():???????? ????????????????return?j?*?j? ????????????return?g ????????r?=?f(i) ????????fs.append(r) ????return?fs f1,?f2,?f3?=?count() print?f1(),?f2(),?f3()
建議你仔細(xì)看看python閉包知識,http://idcbgp.cn/code/6059。

檸檬
TA貢獻(xiàn)1條經(jīng)驗 獲得超0個贊
def count():
? ? fs = []
? ? for i in range(1, 4):
? ? ? ? fs.append(i*i)
? ? return fs
f1, f2, f3 = count()
print (f1, f2, f3)
直接這樣就好了
添加回答
舉報
0/150
提交
取消