mam listę w postaciPowrót min/max wielowymiarowy w Pythonie?
[ [[a,b,c],[d,e,f]] , [[a,b,c],[d,e,f]] , [[a,b,c],[d,e,f]] ... ] etc.
że chcemy zwrócić wartość minimalną i maksymalną c c + Wartość Rf. czy to możliwe?
mam listę w postaciPowrót min/max wielowymiarowy w Pythonie?
[ [[a,b,c],[d,e,f]] , [[a,b,c],[d,e,f]] , [[a,b,c],[d,e,f]] ... ] etc.
że chcemy zwrócić wartość minimalną i maksymalną c c + Wartość Rf. czy to możliwe?
Dla minimalnej c
:
min(c for (a,b,c),(d,e,f) in your_list)
Dla maksymalnej c+f
max(c+f for (a,b,c),(d,e,f) in your_list)
przykład:
>>> your_list = [[[1,2,3],[4,5,6]], [[0,1,2],[3,4,5]], [[2,3,4],[5,6,7]]]
>>> min(c for (a,b,c),(d,e,f) in lst)
2
>>> max(c+f for (a,b,c),(d,e,f) in lst)
11
To wydaje się działać świetnie; Dziękuję Ci! Nie wiedziałem, że możesz to zrobić w ten sposób (A dla B w formacie C) –
Podoba mi się. Nie jestem pewien, czy zrozumienie listy jest najlepszym sposobem * wyjaśnienia * jej początku, ale jest uroczą częścią kodu. –
Och, przy okazji, John, to magiczne określenie, jakiego oczekujesz w przypadku tego rodzaju kodu: "Zrozumienie listy". –
Musisz zmapować swoją listę do jednej zawierającej tylko te elementy, na których Ci zależy.
Oto jeden z możliwych sposobów w ten sposób:
x = [[[5, 5, 3], [6, 9, 7]], [[6, 2, 4], [0, 7, 5]], [[2, 5, 6], [6, 6, 9]], [[7, 3, 5], [6, 3, 2]], [[3, 10, 1], [6, 8, 2]], [[1, 2, 2], [0, 9, 7]], [[9, 5, 2], [7, 9, 9]], [[4, 0, 0], [1, 10, 6]], [[1, 5, 6], [1, 7, 3]], [[6, 1, 4], [1, 2, 0]]]
minc = min(l[0][2] for l in x)
maxcf = max(l[0][2]+l[1][2] for l in x)
The zawartość min
i max
połączeń jest to, co nazywa się "generator", i jest odpowiedzialny za generowanie odwzorowanie oryginalnych danych do przefiltrowanego danych .
List comprehension z pomocą
a=[[[1,2,3],[4,5,6]], [[2,3,4],[4,5,6]]]
>>> min([x[0][2] for x in a])
3
>>> max([x[0][2]+ x[1][2] for x in a])
10
Oczywiście, że to możliwe. Masz listę zawierającą listę dwuelementowych list, które same w sobie są listami. Twój podstawowy algorytm jest
for each of the pairs
if c is less than minimum c so far
make minimum c so far be c
if (c+f) is greater than max c+f so far
make max c+f so far be (c+f)
przypuszczać lista jest przechowywana w my_list:
min_c = min(e[0][2] for e in my_list)
max_c_plus_f = max(map(lambda e : e[0][2] + e[1][2], my_list))
Tak, wszystko jest możliwe. Co próbujesz? – JBernardo
Hmmm. Praca domowa? –
Próbowałem min (lista [0] [2]) itd., Aby spróbować uzyskać maksymalny drugi indeks z 0-go klastra każdego elementu. Nie ma pojęcia, jak to zrobić. –