中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python中遞歸求出列表的最大值

發布時間:2021-08-03 10:40:05 來源:億速云 閱讀:771 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“Python中遞歸求出列表的最大值”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Python中遞歸求出列表的最大值”這篇文章吧。

要求:求出列表中的所有值的最大數,包括列表中帶有子列表的。

按照Python給出的內置函數(max)只能求出列表中的最大值,無法求出包括列表中的子列表的最大值

Python3代碼如下:

#!/usr/bin/env python3
# _*_ coding:UTF-8 _*_
list_tmp = [1,3,5,7,9,11]
print(max(list_tmp))

返回的結果為:11

按照Python3給出內置函數(max)的方法想要違和他的要求求出列表包括子列表的數,他就會給你進行報錯。

圖片如下:

Python中遞歸求出列表的最大值

按照上述的操作我們無法將列表的值和子列表的值進行對比,那么我們可以嘗試著自己制作一個可以對比列表和子列表的值,這個方法特別簡單,使用遞歸函數對每個值進行對比,包括子列表的值。

思路:

使用遞歸函數的方式列出,首先我們將每個列表的值全部列出來,在此我們使用循環的方式將列表中的值列出,然后對列表值的類型進行判斷,如果值的類型為list,那么我們就再次列出列表中的值,以此類推,我們就能夠得出所有的列表值,其中無一個是list的類型。

然后我們的函數中將返回結果給出一個默認值,值為0,然后在將返回值跟列表所列出來的值進行對比,如果誰大,那么返回結果的值將等于他,以此類推,我們最終得出的結果就是正個列表中的最大值,說著可能有點難懂,那么直接上代碼。

Python3代碼如下:

def max_value(ls,rs):
 for l in ls:
  if type(l) == list:
   rs = max_value(l,rs)
   continue
  if l > rs:
   rs = l
 return rs
def max_val(ls):
 rs = max_value(ls,0)
 return rs
if __name__ == '__main__':
 list1 = [4,1,3,11,[1,6,8],[[1,3],[6,15]]]
 list2 = [5,[5,7,9,2],3,[2,6,16],9]
 result1 = max_val(list1)
 result2 = max_val(list2)
 print('list1:%r\nMAX:%s\nlist2:%r\nMAX:%s' %(list1,result1,list2,result2))

效果圖如下:

Python中遞歸求出列表的最大值

這里我們依靠遞歸函數的作用,將所有表值全部取下,并且進行判斷。

以上是“Python中遞歸求出列表的最大值”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清新县| 遂川县| 江口县| 丹棱县| 光泽县| 营口市| 隆尧县| 金沙县| 东乡| 定远县| 察隅县| 广丰县| 健康| 绥宁县| 嘉荫县| 南丹县| 桃园市| 汝阳县| 绥阳县| 和静县| 静安区| 启东市| 揭西县| 日喀则市| 旬阳县| 资兴市| 江川县| 徐水县| 苗栗市| 哈巴河县| 永年县| 桐梓县| 宁化县| 静乐县| 大厂| 龙川县| 嫩江县| 九寨沟县| 霞浦县| 吉木萨尔县| 天门市|