我在python中有一个列表
my_list = [2,4,6,[5,10,3]]
如何找到最大数字(即程序应该将最大值返回为10)?
由于
答案 0 :(得分:3)
展平你的列表,然后你可以使用max()
内置函数:
l = [2,4,6,[5,10,3]]
def flatten(seq):
for el in seq:
if isinstance(el, list):
yield from flatten(el)
else:
yield el
print(max(flatten(l))) # 10
答案 1 :(得分:1)
可能更短/更好,但有一种方式:
my_list = [2,4,6,[5,10,3]]
print(max(max(x) if isinstance(x, list) else x for x in my_list))
答案 2 :(得分:1)
为了找到最大值,迭代两次对我来说是额外的开销。首先,为了展平列表然后再次找到最大值。下面是创建递归函数以在单次迭代中返回嵌套列表的最大值的示例:
# The good thing is, you need not to worry about the level of depth
# of the nested list, you can use it on any level of nested list
def get_max(my_list):
m = None
for item in my_list:
if isinstance(item, list):
item = get_max(item)
if not m or m < item:
m = item
return m
示例运行:
>>> my_list = [2,4,6,[5,10,3]]
>>> get_max(my_list)
10