~~~~~~~~~~~~~~~~~~~~ Arc.Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~ 
Номер скриншота №:
✰ 72D6A5E77AE121CF9D7860B3824A2684__1675450980 ✰
Заголовок документа оригинал.:
✰ Hybrid algorithm - Wikipedia ✰
Заголовок документа перевод.:
✰ Гибридный алгоритм — Википедия ✰
Снимок документа находящегося по адресу (URL):
✰ https://en.wikipedia.org/wiki/Hybrid_algorithm ✰
Адрес хранения снимка оригинал (URL):
✰ https://arc.ask3.ru/arc/aa/72/84/72d6a5e77ae121cf9d7860b3824a2684.html ✰
Адрес хранения снимка перевод (URL):
✰ https://arc.ask3.ru/arc/aa/72/84/72d6a5e77ae121cf9d7860b3824a2684__translat.html ✰
Дата и время сохранения документа:
✰ 21.06.2024 18:40:49 (GMT+3, MSK) ✰
Дата и время изменения документа (по данным источника):
✰ 3 February 2023, at 22:03 (UTC). ✰ 

~~~~~~~~~~~~~~~~~~~~~~ Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~~ 
Сервисы Ask3.ru: 
 Архив документов (Снимки документов, в формате HTML, PDF, PNG - подписанные ЭЦП, доказывающие существование документа в момент подписи. Перевод сохраненных документов на русский язык.)https://arc.ask3.ruОтветы на вопросы (Сервис ответов на вопросы, в основном, научной направленности)https://ask3.ru/answer2questionТоварный сопоставитель (Сервис сравнения и выбора товаров) ✰✰
✰ https://ask3.ru/product2collationПартнерыhttps://comrades.ask3.ru


Совет. Чтобы искать на странице, нажмите Ctrl+F или ⌘-F (для MacOS) и введите запрос в поле поиска.
Arc.Ask3.ru: далее начало оригинального документа

Гибридный алгоритм — Википедия Jump to content

Гибридный алгоритм

Из Википедии, бесплатной энциклопедии

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

«Гибридный алгоритм» не относится к простому объединению нескольких алгоритмов для решения другой проблемы — многие алгоритмы можно рассматривать как комбинации более простых частей — а только к объединению алгоритмов, которые решают одну и ту же проблему, но отличаются другими характеристиками, особенно производительностью.

Примеры [ править ]

В информатике гибридные алгоритмы очень распространены в оптимизированных реальных реализациях рекурсивных алгоритмов , особенно реализациях в Алгоритмы «разделяй и властвуй» или «уменьшай и властвуй» , где размер данных уменьшается по мере углубления в рекурсию. В этом случае для общего подхода (на больших данных) используется один алгоритм, но в глубине рекурсии он переключается на другой алгоритм, который более эффективен на небольших данных. Типичным примером являются алгоритмы сортировки , где сортировка вставкой, которая неэффективна для больших данных, но очень эффективна для небольших данных (скажем, от пяти до десяти элементов), используется в качестве последнего шага после первоначального применения другого алгоритма, такого как сортировка слиянием или быстрая сортировка . Сортировка слиянием и быстрая сортировка асимптотически оптимальны для больших данных, но накладные расходы становятся значительными, если применять их к небольшим данным, поэтому в конце рекурсии используется другой алгоритм. Высоко оптимизированный алгоритм гибридной сортировки — Timsort , который сочетает в себе сортировку слиянием, сортировку вставкой и дополнительную логику (включая двоичный поиск ) в логике слияния.

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

Еще одним примером гибридных алгоритмов по соображениям производительности являются introsort и introselect , которые объединяют один алгоритм для быстрого усреднения производительности с использованием другого алгоритма для обеспечения (асимптотически) оптимальной производительности в худшем случае. Интросорт начинается с быстрой сортировки , но переключается на сортировку кучей , если быстрая сортировка не продвигается хорошо; аналогично introselect начинается с fastselect , но переключается на медиану медиан, если быстрый выбор не выполняется должным образом.

Централизованные распределенные алгоритмы часто можно рассматривать как гибридные алгоритмы, состоящие из отдельного алгоритма (выполняемого на каждом распределенном процессоре) и комбинированного алгоритма (выполняемого на централизованном распределителе) – они соответствуют соответственно запуску всего алгоритма на одном процессоре или запуску все вычисления на распределителе, объединяющие тривиальные результаты (одноэлементный набор данных от каждого процессора). Базовым примером этих алгоритмов являются сортировки по распределению , особенно используемые для внешней сортировки , которые делят данные на отдельные подмножества, сортируют подмножества, а затем объединяют подмножества в полностью отсортированные данные; примеры включают сегментную сортировку и флэш-сортировку .

Однако в целом распределенные алгоритмы не обязательно должны быть гибридными алгоритмами, поскольку отдельные алгоритмы или алгоритмы объединения или связи могут решать разные проблемы. Например, в таких моделях, как MapReduce , этапы Map и Reduc решают разные проблемы и объединяются для решения другой, третьей проблемы.

См. также [ править ]

Arc.Ask3.Ru: конец оригинального документа.
Arc.Ask3.Ru
Номер скриншота №: 72D6A5E77AE121CF9D7860B3824A2684__1675450980
URL1:https://en.wikipedia.org/wiki/Hybrid_algorithm
Заголовок, (Title) документа по адресу, URL1:
Hybrid algorithm - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть, любые претензии не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, денежную единицу можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)