Jump to content

Троичный поиск

Троичный алгоритм поиска [1] это метод в информатике для поиска минимума или максимума функции унимодальной .

Предположим, мы ищем максимум и что мы знаем, что максимум лежит где-то между и . Чтобы алгоритм был применим, должно быть некоторое значение такой, что

  • для всех с , у нас есть , и
  • для всех с , у нас есть .

Алгоритм

[ редактировать ]

Позволять быть унимодальной функцией на некотором интервале . Возьмите любые две точки и в этом сегменте: . Тогда есть три возможности:

  • если , то искомый максимум не может располагаться слева – . Это означает, что максимум далее имеет смысл искать только в интервале
  • если , что ситуация аналогична предыдущей, с точностью до симметрии. Теперь искомый максимум не может находиться в правой части – , поэтому перейдите в сегмент
  • если , то поиск следует вести в , но этот случай можно отнести к любому из двух предыдущих (в целях упрощения кода). Рано или поздно длина отрезка станет чуть меньше заданной константы, и процесс можно будет остановить.

точки выбора и :

Порядок выполнения

Рекурсивный алгоритм

[ редактировать ]
def ternary_search(f, left, right, absolute_precision) -> float:
    """Left and right are the current bounds;
    the maximum is between them.
    """
    if abs(right - left) < absolute_precision:
        return (left + right) / 2

    left_third = (2*left + right) / 3
    right_third = (left + 2*right) / 3

    if f(left_third) < f(right_third):
        return ternary_search(f, left_third, right, absolute_precision)
    else:
        return ternary_search(f, left, right_third, absolute_precision)

Итерационный алгоритм

[ редактировать ]
def ternary_search(f, left, right, absolute_precision) -> float:
    """Find maximum of unimodal function f() within [left, right].
    To find the minimum, reverse the if/else statement or reverse the comparison.
    """
    while abs(right - left) >= absolute_precision:
        left_third = left + (right - left) / 3
        right_third = right - (right - left) / 3

        if f(left_third) < f(right_third):
            left = left_third
        else:
            right = right_third

     # Left and right are the current bounds; the maximum is between them
     return (left + right) / 2

См. также

[ редактировать ]
  1. ^ «Тройный поиск» . cp-algorithms.com . Проверено 21 августа 2023 г.
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 2fdd6661bf16975d6c8fa60e65c55a40__1692883260
URL1:https://arc.ask3.ru/arc/aa/2f/40/2fdd6661bf16975d6c8fa60e65c55a40.html
Заголовок, (Title) документа по адресу, URL1:
Ternary search - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)