通過可變參數計算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元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
