8-(927)-977-80-70 web-i-seo@yandex.ru
Режим работы: 10-00 до 20-00 МСК

Вы нашли нас по запросу -"Сравнение методов объединения двух отсортированных списков в Python Самара" - это лучшая рекомендация для подрядчика SEO продвижения в городе Самара или по России!

Сравнение методов объединения двух отсортированных списков в Python

Пусть у нас есть два списка (для простоты из целых чисел), каждый из которых отсортирован. Хотим объединить их в один список, который тоже должен быть отсортирован. Эта задача наверняка всем знакома, используется, например, при сортировке слиянием.

 

 

Способов реализации (особенно на python) достаточно много. Давайте разберем некоторые из них и сравним затрачиваемое время на разных входных данных.

Основная идея алгоритма заключается в том, что, поместив по одной метке в начале каждого списка, будем сравнивать отмеченные элементы, брать меньший из них и передвигать метку в его списке на следующее число. Когда один из списков кончается, нужно добавить остаток второго в конец.

 

Входные данные не меняются

Пусть есть два списка list1 и list2.

Начнем с самого простого алгоритма: обозначим метки за i и j и будем брать меньший из list1[i]list2[j] и увеличивать его метку на единицу, пока одна из меток не выйдет за границу списка.

При первом сравнении мы выберем минимальный элемент из двух минимальных в своем списке и подвинемся на следующий элемент, поэтому наименьший элемент из двух списков будет стоять на нулевом месте результирующего. Дальше несложно по индукции доказать, что далее слияние пройдет верно.

Перейдем к коду:

def simple_merge(list1, list2):
    i, j = 0, 0
    res = []
    while i < len(list1) and j < len(list2):
        if list1[i] < list2[j]:
            res.append(list1[i])
            i += 1
        else:
            res.append(list2[j])
            j += 1
    res += list1[i:]
    res += list2[j:] 
    # один из list1[i:] и list2[j:] будет уже пустой, поэтому добавится только нужный остаток
    return res

 

Заметим, что в данном коде используется только перемещение вперед по списку. Поэтому будет достаточно работать с итераторами. Перепишем алгоритм с помощью итераторов.

 

Еще изменим обработку концов списков, так как теперь мы не умеем копировать сразу до конца. Будем обрабатывать элементы до того, когда оба итератора дойдут до конца, при этом, если один уже оказался в конце, будем просто брать из второго.

 

def iter_merge(list1, list2):
    result, it1, it2 = [], iter(list1), iter(list2)
    el1 = next(it1, None)
    el2 = next(it2, None)
    while el1 is not None or el2 is not None:
        if el1 is None or (el2 is not None and el2 < el1):
            result.append(el2)
            el2 = next(it2, None)
        else:
            result.append(el1)
            el1 = next(it1, None)
    return result

 

В этой реализации можно вместо добавления по одному элементу (result.append()) собрать генератор, а потом из него получить список. Для этого напишем отдельную функцию, которая будет строить генератор, а основная функция сделает из него список.

 

def gen_merge_inner(it1, it2):
    el1 = next(it1, None)
    el2 = next(it2, None)
    while el1 is not None or el2 is not None:
        if el1 is None or (el2 is not None and el2 < el1):
            yield el2
            el2 = next(it2, None)
        else:
            yield el1
            el1 = next(it1, None)

def gen_merge(list1, list2):
    return list(gen_merge_inner(iter(list1), iter(list2))) # из генератора получаем список

 

Встроенные реализации

Рассмотрим еще несколько способов слияния через встроенные в python функции.

  • merge из heapq. Как говорит документация, эта функция делает именно то, что мы хотим, и больше: объединяет несколько итерируемых объекта, можно задать ключ, можно сортировать в обратном порядке.
    Тогда нам нужно просто импортировать и использовать:

    from heapq import merge
    
    def heapq_merge(list1, list2):
        return list(merge(list1, list2)) # тоже возвращает генератор
  • Counter из collectionsCounter умеет считать количество вхождений каждого из элементов, выдавать их в тех количествах, в которых они входят, и еще несколько полезных вещей, которые сейчас не нужны (например, несколько самых часто встречающихся элементов).
    Воспользуемся gen_merge_inner для слияния элементов Counter(list1) и Counter(list2):

    def counter_merge(list1, list2):
        return list(gen_merge_inner(Counter(list1).elements(), Counter(list2).elements()))
  • И, наконец, просто сортировка. Объединяем и сортируем заново. Тут есть два варианта реализация через sort() и sorted(). Сразу сравним их:
list1 = [i for i in range(1, 200000, 3)]
list2 = [i for i in range(2, 250000, 4)]
%timeit res1 = sorted(list1 + list2)
%timeit res2 = list1 + list2; res2.sort()
6.73 ms ± 64.9 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)
4.43 ms ± 38.4 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)

В результате:

    def sort_merge(list1, list2):
        return (list1 + list2).sort()

Если можно менять исходные списки

 

Предположим, что после слияния старые списки больше не нужны (как обычно и случается). Тогда можно написать еще один способ. Будем как и раньше сравнивать нулевые элементы списков и вызывать pop(0) у списка с меньшим, пока один из списков не закончится.

 

def pop_merge(list1, list2):
    result = []
    while list1 and list2:
        result.append((list1 if list1[0] < list2[0] else list2).pop(0))
    return result + list1 + list2

 

Получили простенькую функцию на 4 строчки, но использовать дальше исходные списки не получится. Можно их скопировать, потом работать с копиями, но это потребует много дополнительного времени. Здесь будут проблемы с тем, что удаление нулевого элемента очень дорогое. Поэтому еще одна модификация будет заключаться в том, что мы будем вместо удаления из начала списка использовать удаление из конца, но придется в конце развернуть списки.

 

def reverse_pop_merge(list1, list2):
    result = []
    while list1 and list2:
        result.append((list1 if list1[-1] > list2[-1] else list2).pop(-1))
    return (result + list1[-1::-1] + list2[-1::-1])[-1::-1]

 

Сравнение

 

Пора перейти к самому интересному.
Составим список функций, которые будем сравнивать:

 

  • simple_merge
  • iter_merge
  • gen_merge
  • heapq_merge
  • counter_merge
  • sort_merge
  • pop_merge
  • reverse_pop_merge

 

Будем измерять время работы с помощью модуля timeit. Код можно посмотреть здесь.

 

Разберем несколько ситуаций: оба списка примерно одинакового размера, один список большой, а второй маленький, количество вариантов элементов большое, количество вариантов маленькое. Кроме этого проведем просто общий случайный тест.

Тест первый

 

Проведем общий тест, размеры от $1$ до $10^5$, элементы от $1$ до $10^6$.

 

Отдельно сравним pop и reverse_pop:

 

 

pop_merge тратит колоссально больше времени в общем случае, как и ожидалось.

 

Не будем учитывать здесь огромный pop_merge, чтобы лучше видеть разницу между другими:

 

 

reverse_pop_merge показал себя относительно неплохо по сравнению с ручной реализацией и heapq_merge.

 

Методы на итераторах работают еще быстрее, при этом видно, что получилось выгоднее построить генератор, чем добавлять элементы в список.

 

Тест второй, сравнимые размеры

 

Размеры будут принадлежать отрезку $[50x, 50(x+1))$, а $x$ увеличиваем, начиная с $1$. Шаг $50$.

 

 

Как уже можно видеть pop_merge при небольшом размере списков еще ведет себя как heapq_merge, а дальше обгоняет всех.

 

Тест третий, один маленький, второй большой

 

Размер первого равен $x$, размер второго $10^4 + 100x$.

 

 

В самом начале (на очень маленьких списках) reverse_pop_merge обгоняет всех, кроме sort_merge, но на чуть больших все выходит на стандартные позиции.

 

Тест четвертый, много повторных

 

Размеры фиксированы, а количество элементов увеличивается на $5$, начиная с $1$.

 

 

Как видно, на достаточно малых количествах counter_merge оказывается быстрее reverse_pop_merge и heapq_merge, но потом он отстает.

 

Чемпионы

Абсолютным победителем оказался sort_merge! Гораздо быстрее просто отсортировать список заново, чем использовать вроде бы линейные от длины списков функции.

На втором месте в подавляющем большинстве случаев идет gen_merge, за ним следует iter_merge.

Остальные методы используют еще больше времени, но некоторые в каких-то крайних случаях достигают результатов 2-3 мест.

Дата изменения


Индивидуальный Предприниматель Ознобин Р.А.
8-927-977-80-70
Адрес: г. Самара, ул. Строителей, строение 12

Полезная информация по теме - Сравнение методов объединения двух отсортированных списков в Python Самара

разработка сайта магазина Самара

Качественная создание сайта магазина Самара по доступным ценам закажите прямо сейчас у нас на странице заказа. Наши лучшие специалисты помогут Вам создать продающий и прибыльный on-line магазин в короткие сроки. На современном рынке on-line-магазин это отдельный канал продаж, который позволяет Вашим клиентам сделать заказ или приобрести Ваши товары и сервис. Сегодня все больше людей желают совершать покупки с помощью  on-lineа, дайте возможность им найти Вас. Ваш on-line-магазин  поможет привлечь новых клиентов в ваш бизнес, что в свою очередь увеличит скорость, конвертации потенциальных клиентов в покупающих клиентов. Перед тем как разработать on-line магазин, вы должны убедиться, что разработчик правильно реализует Ваш портал. создание сайта магазина Самара с помощью небольшого количества времени и нашей помощи Вы можете создать эффективную и функциональную витрину. может отличаться в зависимости от масштаба и сложности портала. Если Вы хотите вывести свой продукт или...

стоимость медицинского сайта Самара

Готовы Вам оказать сервис по производству и оптимизации информации о Ваших товарах и усилийах. стоимость медицинского сайта Самара Вы можете узнать ознакомившись с нашими ценами по производству или разработки торговой on-line площадки, а так же предлагаем Вам ознакомиться и выбрать подходящий тариф для адаптации медицинского сайта. Стоимость медицинского сайта  Самара может включать в себя установку концепции, его индивидуальный дизайн, проработку юзабилити, покупку домена и размещение его на серверной платформе. Но задумайтесь о том, как люди будут находить Вас в web сети. Большинство сегодня ищут данные в поисковых комплексах. По этому в стоимость медицинского сайта так же может быть включена общая усилийа по оптимизации, которая привлечет пользователей ищущих медицинские сервис или лекарства в сети, т.е. Ваших потенциальных клиентов. Если у Вас возникли вопросы или вы хотите рассчитать стоимость медицинского сайта  Самара, то оставьте заявку онлайн или же свяжитесь для...

Сайт Комбината композитных материалов Самара

Модернизирован и взят на SEO раскрутка — новый сайт. Комбинат композитных материалов, г Саранск — занимается производством инновационной продукции — пластиковой арматуры и композитной сетки БАЗИС. Перед заказчиком прежде всего стоял вопрос адаптации сайта в поисковых комплексах по запросам о продукции комбината, а также возможность самостоятельного редактирования и добавления информации и вопрос размещения видео на страницах сайта. Посмотреть сайт заказчика … ...

seo продвижение сайта цена Самара

раскрутка сайта цена Самара  при комплексном заказе сервис будет включать в себя обмен ссылками с другими on-line источниками информации, что бы увеличить количество переходов целевой аудитории к Вам. Но важно не только это, важно и качество обмена ссылками, это определяет саму целевую аудиторию, т.е. соответствующую Вашим запросам. Поэтому мы сосредоточим свои усилия по производству ссылок на соответствующих качественных ресурсах. Сравнение методов объединения двух отсортированных списков в Python — получи СКИДКУ 10% Как правило, затраты на сео раскрутку Вашего портала зависят от того, хотите ли Вы размещать статьи, и проводить обмен с другими инетернет площадками, блогами, журналами и т. д. Мы можем это делать в рамках комплексного обслуживания Вашей on-line площадки по оптимизации в web сети. Так же раскрутка сайта Самара заключается в том, что если мы публикуем Ваши статьи на...

Лучший инновационный предприниматель 2013 года в Мордовии! Самара

ООО «Код Эксперт», а с ней и ООО «Код Экперт — РМ» стала победителем конкурса   Министерства Торговли и Промышленности Республики Мордовия «Лудший предприниматель 2013 года» в номинации «инновации и эффективные технологии». Министр Владимир Викторович Руженков отметил, что «Код Эксперт» является одним из «птенцов» «ГКУ «Бизнес – инкубатор Республики Мордовия»,  который «вылетел» из его «гнезда» и превратился в состоявшуюся и востребованную инновационную компанию. Данное признание со стороны министерства и правительства в целом, мы получили за успешную установку и внедрение Серверной платформы СП «Прометей». СП «Прометей» комплекс на основе Linux CentOs и пакета собственных программных разработок ООО «Код — эксперт». Данный комплекс позволяет в 90% случаев эффективно замещать аналогичный по свойствам Windows Server 2012, при значительно меньшей цене. И всю выручку оставлять на территории Мордовии и РФ. В...

разработка сайтов цена Самара

Что бы создание сайтов цена Самара на который будет доступна Вашему бюджету, отвечала Вашим поставленным задачам обратитесь к нам. Более 15 лет опыта в разработке для разных направлений в бизнесе, делает нас гарантом хорошего результата. Цены на наши сервис Вы можете уточнить в этом разделе или же сделав заявку онлайн, тогда мы произведем расчет соответствующий Вашим задачам и требованиям. Если же Вам необходима консультация Вы можете позвонить нам и мы ответим на все интересующие вопросы. создание сайтов цена Самара может колебаться от 3-4 тыс руб. и доходит до сотен тысяч у разных компаний, в первую очередь это зависит от ценовой политики компании разработчика и от сложности выполнения портала. Мы предлагаем Вам заказать установку под ключ, цены на которые зависят от Ваших целей и сложности портала. Но в любом случае цена на оказываемые нами сервис более доступны, поэтому к нам обращаются за комплексом работ по производству и оптимизации сайтов. Качественная создание Самара,...

seo продвижение сайта заказать Самара

раскрутка сайта заказать Самара у нас Вы можете ознакомившись с нашими предложениями или связавшись любым удобным способом с нашим специалистом. Правильно построенная стратегия реализации портала с нами даст Вам прямую конвертацию в доход Вашего дела. Сравнение методов объединения двух отсортированных списков в Python — получи СКИДКУ 10% Работы по поднятию в ТОП поисковых систем (Яндекс, Гугл) или  раскрутка сайта заказать как правило подразумевает 3 области анализа и действий ежемесячно: Анализ конкуренции, активности и спроса по целевым запросам. Оценка целесообразности CEO работ. Анализ контента на правильность его построения и присутствия всех необходимых элементов для адаптации. Правка метаданных фотографий и акцентов контента страниц. Создание новостных статей по целевым разделам. Анализ метаданных целевых страниц на соответствие целевым запросам и их правка. Анализ...

продвижение сайта в поисковых системах Самара

Несмотря на то, что раскрутка сайта в поисковых комплексах Самара  может показаться слишком сложным, особенно когда люди начинают сталкиваться с такими терминами, как “поисковая система”, “поисковая оптимизация” и “поисковые термины”. Раскрутка сайта в поисковых комплексах Самара  имеет основной набор понятий и правил, которые делают процесс адаптации вашего бизнес-сайта четким и простым набором шагов. Сравнение методов объединения двух отсортированных списков в Python — получи СКИДКУ 10% Что такое раскрутка сайта в поисковых комплексах и почему вы должны задуматься об этом? Почему вы должны заботиться о раскрутки сайта в поисковых комплексах Самара ? Позаботимся об этом мы! Но Вам необходимо знать зачем это необходимо. раскрутка сайта в поисковых комплексах необходимо что бы настроить структуру вашего сайта и страницы так, что Ваши посетители, клиенты и поисковые системы (например, Google, Yandex и...