Python reduce()函數(shù)的用法小結(jié)
reduce()函數(shù)也是Python內(nèi)置的一個高階函數(shù)。
reduce()
格式:
reduce (func, seq[, init()])
reduce()函數(shù)即為化簡函數(shù),它的執(zhí)行過程為:每一次迭代,都將上一次的迭代結(jié)果(注:第一次為init元素,如果沒有指定init則為seq的第一個元素)與下一個元素一同傳入二元func函數(shù)中去執(zhí)行。在reduce()函數(shù)中,init是可選的,如果指定,則作為第一次迭代的第一個元素使用,如果沒有指定,就取seq中的第一個元素。
reduce()函數(shù)的執(zhí)行過程如下圖所示:
從reduce函數(shù)的執(zhí)行過程,讓我們很容易聯(lián)想到求一個數(shù)的階乘,而Python中并沒有給出一個求階乘的內(nèi)置函數(shù),正好我們就拿這個例子來說明reduce函數(shù)吧。
#未指定init的情況 >>> n = 6 >>> print reduce(lambda x, y: x * y, range(1, n)) 120
上面的例子中range(1,6)函數(shù)生成的是一個[1, 2, 3, 4, 5]這樣的列表,這里我們給它個名叫seq1吧,reduce()函數(shù)執(zhí)行時,由于沒有指定init參數(shù),所以將取seq1中的第一個元素1,作為第一個元素,由于前面的lambda有2個變量,所以需要兩個實參,于是就取seq1中的第2個元素2,與第一個元素1一起傳入lambda中去執(zhí)行,并將返回結(jié)果2,并同下一個元素3再一起傳入lambda中執(zhí)行,再次返回的結(jié)果,作為下一次執(zhí)行的第一個元素,依次類推,就得出結(jié)果5! = 120。
如果我們希望得到階乘的結(jié)果再多增加幾倍,可以啟用init這個可選項。如:
>>> print reduce(lambda x, y: x * y, range(1, n),2) 240
這個時候,就會將init作為第一個元素,和seq1中的第一個元素1一起傳入lambda函數(shù)中去執(zhí)行,返回結(jié)果再作為下一次的第一個元素。
下面給出的例子更簡單一些,大家可以看下
reduce()函數(shù)接收的參數(shù)和 map()類似,一個函數(shù) f,一個list,但行為和 map()不同,reduce()傳入的函數(shù) f 必須接收兩個參數(shù),reduce()對list的每個元素反復(fù)調(diào)用函數(shù)f,并返回最終結(jié)果值。
例如,編寫一個f函數(shù),接收x和y,返回x和y的和:
def f(x, y): return x + y
調(diào)用 reduce(f, [1, 3, 5, 7, 9])時,reduce函數(shù)將做如下計算:
先計算頭兩個元素:f(1, 3),結(jié)果為4;
再把結(jié)果和第3個元素計算:f(4, 5),結(jié)果為9;
再把結(jié)果和第4個元素計算:f(9, 7),結(jié)果為16;
再把結(jié)果和第5個元素計算:f(16, 9),結(jié)果為25;
由于沒有更多的元素了,計算結(jié)束,返回結(jié)果25。
上述計算實際上是對 list 的所有元素求和。雖然Python內(nèi)置了求和函數(shù)sum(),但是,利用reduce()求和也很簡單。
reduce()還可以接收第3個可選參數(shù),作為計算的初始值。如果把初始值設(shè)為100,計算:
reduce(f, [1, 3, 5, 7, 9], 100)
結(jié)果將變?yōu)?25,因為第一輪計算是:
計算初始值和第一個元素:f(100, 1),結(jié)果為101。
相關(guān)文章
Python 數(shù)據(jù)分析之Beautiful Soup 提取頁面信息
Beautiful Soup 提供一些簡單的、python 式的函數(shù)用來處理導(dǎo)航、搜索、修改分析樹等功能。它是一個工具箱,通過解析文檔為用戶提供需要抓取的數(shù)據(jù),因為簡單,所以不需要多少代碼就可以寫出一個完整的應(yīng)用程序2021-10-10Django使用django-simple-captcha做驗證碼的實現(xiàn)示例
這篇文章主要介紹了Django使用django-simple-captcha做驗證碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01基于Python實現(xiàn)船舶的MMSI的獲取(推薦)
工作中遇到一個需求,需要通過網(wǎng)站查詢船舶名稱得到MMSI碼,網(wǎng)站來自船訊網(wǎng)。這篇文章主要介紹了基于Python實現(xiàn)船舶的MMSI的獲取,需要的朋友可以參考下2019-10-10Pytorch對Himmelblau函數(shù)的優(yōu)化詳解
今天小編就為大家分享一篇Pytorch對Himmelblau函數(shù)的優(yōu)化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02Python最基本的數(shù)據(jù)類型以及對元組的介紹
這篇文章主要介紹了Python最基本的數(shù)據(jù)類型以及對元組的介紹,來自于IBM官方網(wǎng)站技術(shù)文檔,需要的朋友可以參考下2015-04-04python中的torch常用tensor處理函數(shù)示例詳解
這篇文章主要介紹了python中的torch常用tensor處理函數(shù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07詳解如何將Python可執(zhí)行文件(.exe)反編譯為Python腳本
將?Python?可執(zhí)行文件(.exe)反編譯為?Python?腳本是一項有趣的技術(shù)挑戰(zhàn),可以幫助我們理解程序的工作原理,下面我們就來看看具體實現(xiàn)步驟吧2024-03-03