Python: удалить список в списке, если 1-й элемент в списке дублируется, а 2-й элемент является самым низким в серии списков

Попробуйте использовать

Dim imageSource as ImageSource
Dim bitmapDecoder = new PngBitmapDecoder(stream, BitmapCreateOptions.PreservePixelFormat, BitmapCacheOption.OnLoad);
imageSource = bitmapDecoder.Frames[0];
imageSource.Freeze();
Return imageSource
-2
задан Andrew Dunlop 19 March 2019 в 15:28
поделиться

2 ответа

for x in list(all):
    for y in list(all):
        if y[0] == x[0] and y[1] <= x[1] and y is not x:
            all.remove(y)
0
ответ дан Zak Stucke 19 March 2019 в 15:28
поделиться

Будет ли что-то вроде словаря работать лучше здесь?

all = [[123, 1],[456, 1],[789, 1],[123,2],[456, 2],[789,1]]

as_dict = {}
for item in all:
    if not (item[0] in as_dict and as_dict[item[0]] > item[1]):
        as_dict[item[0]] = item[1]

print(as_dict)
# Returns {123: 2, 456: 2, 789: 1}

На самом деле, если вы знаете, что вторые числа в каждой паре никогда не уменьшатся (например, вы не увидите что-то вроде [123,0] появляются позже в списке после [123,2]), тогда просто преобразование списка в словарь с dict() должно выполнить то же самое. Затем вы можете преобразовать его обратно в список, если хотите.

d = dict(all)  # This is {123: 2, 456: 2, 789: 1}
newlist = [ [k,d[k]] for k in d] # This is [[123, 2], [456, 2], [789, 1]]
0
ответ дан Bill M. 19 March 2019 в 15:28
поделиться
Другие вопросы по тегам:

Похожие вопросы: