1、以下選項不是函數作用的是:
A、增強代碼可讀性
B、降低程式設計複雜度
C、提高代碼執行速度
D、複用代碼
正确答案: C
函數不能直接提高代碼執行速度。
2、列程式的輸出結果為:
def f(a,b):
a=4
return a+b
def main():
a=5
b=6
print(f(a,b),a+b)
main()
A、10 11
B、11 11
C、10 10
D、11 10
正确答案: A
這裡沒有全局變量,都是函數局部變量的運算。
3、以下關于Python函數說法錯誤的是:
def func(a,b):
c=a**2+b
b=a
return c
a=10
b=100
c=func(a,b)+a
A、執行該函數後,變量a的值為10
B、執行該函數後,變量c的值為200
C、執行該函數後,變量b的值為100
D、該函數名稱為func
正确答案: B
這裡沒有全局變量,請在IDLE中執行代碼觀察結果。
4、以下關于函數調用描述正确的是:
A、函數在調用前不需要定義,拿來即用就好
B、自定義函數調用前必須定義
C、函數和調用隻能發生在同一個檔案中
D、Python内置函數調用前需要引用相應的庫
正确答案: B
函數調用前必須已經存在函數定義,否則無法執行。
Python内置函數直接使用,不需要引用任何子產品。
5、以下關于子產品化設計描述錯誤的是:
A、子產品間關系盡可能簡單,子產品之間耦合度低
B、應盡可能合理劃分功能塊,功能塊内部耦合度高
C、高耦合度的特點是複用較為困難
D、應盡可能合理劃分功能塊,功能塊内部耦合度低
正确答案: D
子產品内高耦合、子產品間低耦合。
6、以下對遞歸描述錯誤的是:
A、一定要有基例
B、執行效率高
C、遞歸程式都可以有非遞歸編寫方法
D、書寫簡單
正确答案: B
遞歸不提高程式執行效率。
任何遞歸程式都可以通過堆棧或隊列變成非遞歸程式(這是程式的進階應用)。
7、以下關于函數說法錯誤的是:
A、函數可以看做是一段具有名字的子程式
B、對函數的使用必須了解其内部實作原理
C、函數是一段具有特定功能的、可重用的語句組
D、函數通過函數名來調用
正确答案: B
調用函數不需要知道函數内部實作原理,隻需要知道調用方法(即接口)即可。
8、哪個選項對于函數的定義是錯誤的?
A、def vfunc(a,b):
B、def vfunc(a,b=2):
C、def vfunc(a,*b):
D、def vfunc(*a,b):
正确答案: D
def vfunc(*a, b) 是錯誤的定義:*a表示可變參數,可變參數隻能放在函數參數的最後。
9、關于return語句,以下選項描述正确的是:
A、函數必須有一個return語句
B、函數中最多隻有一個return語句
C、return隻能傳回一個值
D、函數可以沒有return語句
正确答案: D
函數可以包含0個或多個return語句
10、以下關于遞歸函數基例的說法錯誤的是:
A、遞歸函數的基例不再進行遞歸
B、遞歸函數的基例決定遞歸的深度
C、每個遞歸函數都隻能有一個基例
D、遞歸函數必須有基例
正确答案: C
每個遞歸函數至少存在一個基例,但可能存在多個基例。
**
随機密碼生成
**
描述:
輸入 | 輸出 |
---|---|
3 | 634 524 926 |
補充程式設計模闆中代碼,完成如下功能:
以整數17為随機數種子,擷取使用者輸入整數N為長度,産生3個長度為N位的密碼,密碼的每位是一個數字。每個密碼單獨一行輸出。
産生密碼采用random.randint()函數。
import random
def genpwd(length):
a = pow(10, length - 1) # 定義一個下限
b = pow(10, length) - 1 # 定義一個上限
return "{}".format(random.randint(a, b)) # 生成a , b
# 範圍内的整數
length = eval(input())
random.seed(17)
for i in range(3):
print(genpwd(length))
**
連續質數計算
**
描述:補充程式設計模闆中代碼,完成如下功能:
獲得使用者輸入數字N,計算并輸出從N開始的5個質數,單行輸出,質數間用逗号,分割。
注意:使用者輸入的數字N可能是浮點數,都是正數;最後一個輸出後不用逗号。
輸入 | 輸出 |
---|---|
12 | 13,17,19,23,29 |
def prime(m):
end = int(pow(m, 0.5) + 1)
for i in range(2, end):
if m%i == 0:
return False
else:
return True
n = eval(input())
if n != int(n): # 因為可能輸入有浮點數
n = int(n) + 1
else:
n = int(n)
count = 5
while count > 0:
if prime(n):
if count > 1:
print(n, end=',')
else:
print(n)
count -= 1
n += 1