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 сети. У нас действительно Вы можете купить сайт под ключ недорого, но мы рекомендуем заказывать не только изготовление, но и его раскрутка в web сети, ведь именно это дает посещение и совершение сделок в web сети. Мы предлагаем Вам купить готовый...

Аренда интернет магазина Пермь

Здравствуйте. У нас есть уникальное предложение для владельцев магазинов! У вас есть бизнес и вы хотите торговать через on-line магазин? Мы предлагаем Вам партнёрскую программу, которая позволит Вам иметь новый канал продаж, техническую поддержку, маркетинговую и SEO поддержку, БЕЗ ПРЕДВАРИТЕЛЬНЫХ ЗАТРАТ ! Мы готовы работать за проценты с реальных продаж ! По предварительному соглашению — мы предоставим Вам : Хостин (вычислительные мощности где «крутится сайт» и тех обслуживание ПО) Ваш индивидуальный домен (имя сайта — по согласованию с Вами) Сайт (Хорошо отлаженный, работающий на мобильных ив браузерах он-лайн магазин) Техническую поддержку (Мы полностью обеспечим работоспособность сайта и его обновления) SEO раскрутка (Мы будем своими силами и средствами продвигать Ваш сайт в ТОП 10) Маркетинговую поддержку ( Мы предоставим Вам хорошо продуманные варианты рекламных компаний на Ваш выбор и будем их технически обслуживать ) Что от Вас — Наполнение...

Корпоративный портал поставщика строительных материалов Пермь

Новый сайт — ООО «ДанСтар». Занимаются поставкой строительных материалов и комплектующих на строительные объекты Нижнего Новгорода и Нижегородской области. Заказчику был необходим простой сайт с перечнем поставляемой продукции и формой обратной связи. ООО «ДанСтрой» решили заказать сайт с минимальной функциональностью и простым дизайном, но с наполнением материалов сайта и товаров, и отлаженными мета описаниями и ключевыми словами, для ускорения адаптации сайта в результатах поиска Гугл и Яндекс по Нижнему Новгороду. Базовая цена сайта составила — 9600 руб. ! наполнение сайта материалами — от 300 до 900 руб. за страницу  (в зависимости от наличия таблиц) Стоимость визуальных эффектов сайта — 5000 руб.. Что бы заказать сайт у нас, вам надо лишь отправить заявку с данного сайта или связаться с нами любым из перечисленных в разделе Контакты методов. Мы свяжемся с Вами и поможем определится с техническим заданием, дизайном и ценой...

разработка сайта компании Пермь

За короткий срок и по доступной цене создание сайта компании Пермь с последующим обслуживанием и раскруткам. Делаем простые и сложные автоматизированные и продающие on-line витрины и корпоративные площадки. Нашими основными направлениями являются создание и раскрутка порталов компании Пермь, любой сложности и функционала. Выбирая разработчика Вы увидите большое количество предложений которые усложняют Ваш выбор, особенно если Вы не специалист данной области. Пытаясь самостоятельно разобраться с чего начинается создание портала для компании, Вам придется изучить тонкости on-lineа, стандарты разработки ИТ порталов, оптимизацию программных процессов (скорость загрузки очень важна для посетителей), провести анализ взаимодействия с поисковыми системами и многие другие нюансы разработки — раскрутки порталов. компании занимающиеся разработкой сайтов Пермь, расскажут Вам хорошую историю, сделают убедительную презентацию, но от куда Вы будете знать, что результат Вас...

продвижение сайта в топ цена Пермь

Вывести свой бизнес на новый рынок или увеличить долю продав в web сети позволяет сервис раскрутка сайта в топ цена Пермь указана ниже в таблице, где Вы можете выбрать наиболее для Вас подходящий и выгодный вариант. раскрутка сайта в топ цена Пермь — При предоплате за 3-месяца и получи скидку 10%. Вы нашли нас в ТОП10 поиска по запросу «раскрутка сайта в топ цена» Пермь — это лучшая реклама!!! Раскрутка on-line портала в Вашем городе Пермь или других регионах уже включает в себя комплексное обслуживание, в том числе закупку и ручной обмен внешними ссылками, ручная корректировка метаданных вашего контента и создание качественного целевого контента в ведомых разделах, трансляция целевого контента в «соцсети поддержки». В правильно ориентированном контенте есть много «подводных камней» и текст должен быть выверен до мелочей. Важно не просто правильно подстроенный контента под поисковую систему, но и хорошо когда...

Корпоративный сайт от 5000 рублей! Пермь

Пермь — Сделай заказ SEO сразу на 3-месяца и получи «Корпоративный Сайт Стандар» за 5000р. Вы нашли нас в ТОП10 поиска по запросу «Корпоративный сайт от 5000 руб.!» Пермь — это лучшая реклама!!! Главное отличие Корпоративного сайта от Сайта Визитка состоит в возможности управления контентом страниц сайта и возможностью добавлять новые страницы и рубрики (Например — Новости, Акции, Скидки и тп) Для Вас Пермь — Мы предлагаем вашему вниманию готовое решение «Корпоративный сайт Минимум» от 7500р. и «Корпоративный сайт Стандарт» от 10000р. — это полноценный портал небольшой коммерческой организации,  индивидуального предпринимателя или частной практики. Такое «Готовое решение» содержит весь минимально необходимый функционал для размещения информации и получения заявок от потенциальных клиентов вашего дела. В готовых решениях используется дизайн интерфейса на основе уже готовых шаблонов...

разработка коммерческого сайта Пермь

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