通過可變參數計算n個數的乘積:
代碼如下:
list = []
def the_input(count=eval(input("輸入乘數的總個數:"))):
for i in range(count):
N=eval(input("依次輸入乘數:"))
list.append(N)
print("一共有",count,"個要相乘的數")
print("把這些乘放在列表里面:",list)
the_input()
def get_mul(*num):
sum =1
for n in num:
sum = sum * n
return sum
print("這鞋數相乘的最終結果是:",get_mul(*list))
運行結果
可變參數 解釋
在Python函數中,還可以定義可變參數。顧名思義,可變參數就是傳入的參數個數是可變的,可以是1個、2個到任意個,還可以是0個。
我們以數學題為例子,給定一組數字a,b,c……,請計算a2 + b2 + c2 + ……。
要定義出這個函數,我們必須確定輸入的參數。由于參數個數不確定,我們首先想到可以把a,b,c……作為一個list或tuple傳進來,這樣,函數可以定義如下:
def calc(numbers):
sum = 0
for n in numbers:
sum = sum + n * n
return sum
但是調用的時候,需要先組裝出一個list或tuple:
calc([1, 2, 3])
14
calc((1, 3, 5, 7))
84
如果利用可變參數,調用函數的方式可以簡化成這樣:
calc(1, 2, 3)
14
calc(1, 3, 5, 7)
84
所以,我們把函數的參數改為可變參數:
def calc(*numbers):
sum = 0
for n in numbers:
sum = sum + n * n
return sum
定義可變參數和定義一個list或tuple參數相比,僅僅在參數前面加了一個*號。在函數內部,參數numbers接收到的是一個tuple,因此,函數代碼完全不變。但是,調用該函數時,可以傳入任意個參數,包括0個參數:
calc(1, 2)
5
calc()
0
如果已經有一個list或者tuple,要調用一個可變參數怎么辦?可以這樣做:
nums = [1, 2, 3]
calc(nums[0], nums[1], nums[2])
14
這種寫法當然是可行的,問題是太繁瑣,所以Python允許你在list或tuple前面加一個*號,把list或tuple的元素變成可變參數傳進去:
nums = [1, 2, 3]
calc(*nums)
14
*nums表示把nums這個list的所有元素作為可變參數傳進去。這種寫法相當有用,而且很常見。
以上這篇python 通過可變參數計算n個數的乘積方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

