最贊回答 / 慕蓋茨6013945
我是這樣理解的,sort其實是按照順序的,就是x&個判斷y就按照x y ;x&等于1y就按照x&函數自y,x=y就是0,然后這個判斷的標準就是-1 1 0,然后至于是等于1還是-1 還是0就是你的函數自己決定的,如果沒用定義函數...
2020-04-23
已采納回答 / qq_慕萊塢2421672
這句是個輸出代碼,輸出內容為'call %s() in %fs',內容中應用了格式化輸出%s,它的作用就是先在輸出內容中占個位置,然后再把% (f.__name__, (t2 -t1))中的變量值按順序替換輸出內容中的%s。__name__是python中的內建變量,標識模塊的名字,所以f.__name__就是返回f的名字
2020-04-21
這樣是不是好理解點,寫得太簡潔不容易理解,而且容易出錯
class Fib(object):
def __call__(self, num):
L = []
m = 0
n = 1
for i in range(0, 10):
L.append(m)
temp = m
m = n
n = temp + n
return L
f = Fib()
print f(10)
class Fib(object):
def __call__(self, num):
L = []
m = 0
n = 1
for i in range(0, 10):
L.append(m)
temp = m
m = n
n = temp + n
return L
f = Fib()
print f(10)
2020-04-19
最贊回答 / qq_戲子_6
很好理解啊,for循環執行了完了,i就是成的range(1,4)生成的list[1,2,3]的最后一個值,猶如函數f1,f2,f3是for循環結束的時候你才調用的,所以就變成3*3了,如果你for循環一次就直接返回就1*1了,如:def count():? ? fs = []? ? for i in range(1,4):? ? ? ? def f():? ? ? ? ? ? return i*i? ? ? ? fs.append(f)? ? ? ? break? ? return fsf1 = coun...
2020-04-18
def calc_prod(lst):
def lazy_prod():
sum=1
for x in lst:
sum=sum*x
return sum
return lazy_prod
f = calc_prod([1, 2, 3, 4])
print f()
def lazy_prod():
sum=1
for x in lst:
sum=sum*x
return sum
return lazy_prod
f = calc_prod([1, 2, 3, 4])
print f()
2020-04-17
def cmp_ignore_case(s1, s2):
if s1.upper()>s2.upper():
return 1
if s1.upper()<s2.upper():
return -1
return 0
print sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
if s1.upper()>s2.upper():
return 1
if s1.upper()<s2.upper():
return -1
return 0
print sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
2020-04-17
最新回答 / 超小咪
閉包是對于兩個函數的,當進入外部函數時,如果內部函數引用了外部函數的變量,那么這個變量在進入外部函數那一刻就應該是不變的。g() == 外部函數、 h() == 內部函數? j就是這個變量? h()入不入參不影響
2020-04-16
我們打斷點可以發現在for循環里根本就沒有進入到f()方法里也就是說append(f)沒有觸發f方法,只是在最后輸出的時候才會進入return j*j,但是我們如果改成append(f())就能順利輸出1,4,9了
2020-04-16
if math.sqrt(x)%2==0:
return x
if math.sqrt(x)%2==1:
return x
雖然做法是對的,但是方法感覺有點笨拙
return x
if math.sqrt(x)%2==1:
return x
雖然做法是對的,但是方法感覺有點笨拙
2020-04-15
>>> from functools import reduce
>>> def prod(x,y):
return x*y
>>> print(reduce(prod,[2,3,4,5]))
120
>>> def prod(x,y):
return x*y
>>> print(reduce(prod,[2,3,4,5]))
120
2020-04-15