هل تريد تسوية قائمة أو مجموعة للبحث عن القيمة القصوى في Python؟

0

أحاول أن أجد القيمة القصوى لقائمة أو مجموعة تحتوي على قوائم أو مجموعات أخرى. فكرتي الأولى هي تسويتها ثم استخدام وظيفة max () للعثور على الحد الأقصى من القائمة الإجمالية ، لكني أواجه صعوبة في القيام بذلك. أي اقتراحات؟

على سبيل المثال ، لديك المجموعة: (1 ، 2 ، 3 ، (1 ، 2)) والناتج المتوقع سيكون 3

مثال آخر هو قائمة [1 ، (2 ، 3) ، [4 ، 5]] ويجب أن يكون الناتج 5

يستغرق ذلك اثنين باستخدام وظيفة التسوية واستدعائها:

def flatten(t):
output = []
for item in t:
    if type(item) != type([]) or type(()):
        output.append(item)
    else:
        output.extend(flatten(item))
return output

def max_val(t):
    flatten(t)
    return max(output)

3 الاجابة

1
افضل جواب

يمكنك تحديد وظيفة عامة لتسوية المدخلات الخاصة بك باستخدام chain.from_iterable و collections.Iterable :

from itertools import chain
from collections import Iterable

x = (1, 2, 3, (1, 2))
y = [1, (2, 3), [4, 5]]

def flatten(x):
    return chain.from_iterable([i] if not isinstance(i, Iterable) else i for i in x)

res = max(flatten(x)) # 3

res = max(flatten(y)) # 5
:مؤلف
0

يمكنك جعل وظيفة مخصصة لتسوية الخاص بك وقابل للتكرار ومعيار الاستخدام max أو min المهام:

from collections.abc import Iterable

x = (1, 2, 3, (1, 2))

def my_flatten(iterable):
    for value in iterable:
        if isinstance(value, Iterable):
            yield from my_flatten(value)
        else:
            yield value

print('min = ', min(my_flatten(x)))
print('max = ', max(my_flatten(x)))

المخرجات:

min =  1
max =  3
:مؤلف
0

يمكنك استخدام الحزمة more_itertools لتسوية ما لديك.

import more_itertools
lst = [[1, 2, 3], [4, 5, 6], [7], [8, 9]]
res = list(more_itertools.flatten(lst))

ثم تحتاج فقط إلى استخدام الدالة max ().

:مؤلف

أسئلة ذات صلة

فوق
قائمة طعام