函數(shù)二
1. 函數(shù)的返回值

- 通過(guò)return來(lái)指定函數(shù)的返回值
- 可以通過(guò)一個(gè)變量來(lái)接收函數(shù)的返回值,也可以直接使用函數(shù)的返回值

- return后?可以跟任意對(duì)象,返回值甚?可以是?個(gè)函數(shù)


- 如果僅僅寫一個(gè)return 或者沒(méi)有寫return 相當(dāng)于 return None

- return一旦執(zhí)行函數(shù)自動(dòng)結(jié)束,return后面的語(yǔ)句不執(zhí)行

- 利用r=fn4() print(r) 才會(huì)返回return后面的值,沒(méi)有則返回None
- return可以用來(lái)結(jié)束函數(shù)

-
返回值就是函數(shù)執(zhí)?以后返回的結(jié)果
用return代替prin,可以直接進(jìn)行運(yùn)算
2. ?檔字符串
- help()是Python中內(nèi)置函數(shù),通過(guò)help()函數(shù)可以查詢Python中函數(shù)的?法
'''
help()
通過(guò)help()函數(shù)可以查詢其他函數(shù)的用法
語(yǔ)法: help(函數(shù)對(duì)象)
'''
help(print)
- 在定義函數(shù)時(shí),可以在函數(shù)內(nèi)部編寫?檔字符串,?檔字符串就是對(duì)函數(shù)的說(shuō)明
def fn(a:int,b:str,c:bool)->int: # 或者簡(jiǎn)略寫也可以def fn(a,b,c):
.... '''
....這個(gè)函數(shù)的功能就是一個(gè)文檔字符串在函數(shù)中的使用說(shuō)明
....參數(shù)
....a,作用,類型,默認(rèn)值...
....b,作用,類型,默認(rèn)值...
....c,作用,類型,默認(rèn)值...
....返回值
....'''
....return 1
help(fn)
3. 函數(shù)的作?域
- 作?域(scope)
- 作?域指的是變量?效的區(qū)域
- 在Python中?共有兩種作?域
1.全局作?域
全局作?域在程序執(zhí)?時(shí)創(chuàng)建,在程序執(zhí)?結(jié)束時(shí)銷毀
所有函數(shù)以外的區(qū)域都是全局作?域
在全局作?域中定義的變量,都是全局變量,全局變量可以在程序的任意位置進(jìn)?訪問(wèn)
2.函數(shù)作?域
函數(shù)作?域在函數(shù)調(diào)?時(shí)創(chuàng)建,在調(diào)?結(jié)束時(shí)銷毀
函數(shù)每調(diào)??次就會(huì)產(chǎn)??個(gè)新的函數(shù)作?域
在函數(shù)作?域中定義的變量,都是局部變量,它只能在函數(shù)內(nèi)部被訪問(wèn) -
從里面可以看到外面(變量),從外面看不到里面(變量)
4. 命名空間
- 命名空間實(shí)際上就是?個(gè)字典,是?個(gè)專??來(lái)存儲(chǔ)變量的字典
- locals()?來(lái)獲取當(dāng)前作?域的命名空間
- 如果在全局作?域中調(diào)?locals()則獲取全局命名空間,如果在函數(shù)作?域中調(diào)?locals()則獲取函數(shù)命名空間
- 返回值是?個(gè)字典
全局

函數(shù)


- 在函數(shù)內(nèi)部獲取一個(gè)全局的命名空間
定義一個(gè)global 獲取到外面的20 30

5. 遞歸函數(shù)
例:嘗試求10的階乘(10!)
1! = 1
2! = 1 * 2 = 2
3! = 1 * 2 * 3 = 6
n = 10
for i in range(1,10):
....n *= i
print(n)
結(jié)果:3628800
例:定義一個(gè)函數(shù) 求任意數(shù)的階乘

- 遞歸是解決問(wèn)題的?種?式(它和循環(huán)非常的像),它的整體思想,是將?個(gè)?問(wèn)題分解為?個(gè)個(gè)的?問(wèn)題,直到問(wèn)題?法分解時(shí),再去解決問(wèn)題
- 遞歸式的函數(shù)
遞歸簡(jiǎn)單理解就是自己調(diào)用自己
遞歸式函數(shù)就是在函數(shù)中自己調(diào)用自己
def fn2():
....fn2() - 遞歸式函數(shù)有2個(gè)條件
- 基線條件 問(wèn)題可以被分解為最?問(wèn)題,當(dāng)滿?基線條件時(shí),遞歸就不執(zhí)?了
- 遞歸條件 可以將問(wèn)題繼續(xù)分解的條件
例:用遞歸的方式來(lái)解決 任意數(shù)的階乘
10! = 10 * 9!
9! = 9 * 8!
...
1! = 1

練習(xí):定義一個(gè)函數(shù) 來(lái)為任意數(shù)字做任意冪運(yùn)算 n ** i
10 ** 5 = 10 * 10 ** 4
10 ** 4 = 10 * 10 ** 3
...
10 ** 1 = 10

作業(yè):定義一個(gè)函數(shù),用來(lái)檢查一個(gè)任意的字符串是否是回文字符串,如果是返回True,不是返回False?;匚淖址畯那巴竽詈蛷暮笸澳钍且粯拥?。例如 TNT
print(fn('aba'))
用遞歸的思想來(lái)解決
'''
abcdefgfedcba
如果是一個(gè)字符肯定是回文
先檢查第一個(gè)字符和最后一個(gè)字符是否一致,如果不一致則不是回文
bcdefgfedcb 是不是回文
cdefgfedc 是不是回文
defgfed 是不是回文
....
g 是不是回文
'''




