Хобрук: Ваш путь к мастерству в программировании

Проблемы с бинарным поиском?

Возможный дубликат:
Каковы подводные камни при реализации бинарного поиска?

Я просматривал страницу Википедии для Двоичный поиск и наткнулся на цитату Кнута ниже:

«Хотя основная идея бинарного поиска сравнительно проста, детали могут оказаться на удивление сложными».

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

Какие детали имеет в виду Кнут? Какие распространенные ошибки следует учитывать при реализации алгоритма бинарного поиска?

Обратите внимание, что я читал статью Блоха об ошибке Programming Pearls (переполнение int для средней точки). Что-нибудь еще?



Ответы:


1

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

16.06.2011
  • Вау, Кнут для тебя Дональд? ;-) 16.06.2011
  • Хе-хе, оговорка, недавно мне пришлось отвести своих детей в один известный фаст-фуд. 16.06.2011

  • 2

    Одним из лучших справочников по сложным вопросам бинарного поиска является Programming Pearls Джона Бентли

    целая глава 4 посвящена этой проблеме, в которой показано множество неверных версий. бинарного поиска.

    например вы хотите найти первое число, которое больше или равно вашему запросу x. Подумайте о +1 -1 проблемах. Как вы можете доказать, что ваша процедура абсолютно верна?

    Подумайте об этих проблемах, и вы обнаружите, что это не так просто.

    16.06.2011
    Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

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

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

    Как свинг-трейдеры могут использовать ИИ для больших выигрышей
    По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

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

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..