我的fs[i-1]根據(jù)我的估計(jì),在循環(huán)過程中會(huì)產(chǎn)生fs[0],fs[1],fs[2]這三個(gè)數(shù),不會(huì)超呀??哪位大俠幫忙看看,代碼很短的#?-*-?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)驗(yàn) 獲得超6個(gè)贊
題主是不是js寫多了呢?我記得js里的數(shù)值可以直接對(duì)數(shù)組任何一個(gè)索引賦值。Python的list是不具備這樣的特性的。
l?=?[]?#?len(l)==0?l的長(zhǎng)度為0,里面不存在任何元素,此時(shí)若l[0]會(huì)引發(fā)索引越界異常,這個(gè)應(yīng)該不難理解 l[0]?=?0?#?這也會(huì)引發(fā)越界異常,因?yàn)閘[0]是不存在的,不能對(duì)其進(jìn)行賦值,Python不像js那樣若不存在就給你創(chuàng)建,而是拋出異常 l.append(0)?#?ok


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

孤獨(dú)的小豬
TA貢獻(xiàn)232條經(jīng)驗(yàn) 獲得超302個(gè)贊
正確代碼應(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閉包知識(shí),http://idcbgp.cn/code/6059。

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