Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/21: Рейтинг темы: голосов - 21, средняя оценка - 4.86
1 / 1 / 0
Регистрация: 18.11.2012
Сообщений: 37

Двоичный поиск в map

03.03.2013, 14:20. Показов 4113. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Помогите разобраться в следующей проблеме.
В общем, мне нужно реализовать двоичный поиск в map по ключам. Понятное дело, тот факт, что ключи в map отсортированы, нас только радует.
Ключи у меня - string. ; т.е. их сортировка идёт по алфавиту. Значения тоже string. У меня значение, которое нужно найти в mymap двоичным поиском по ключам.

Основные вопросы:
1) Как получить доступ к нужному элементу map? Мне нужно что-то типа итератора, который на него указывает.
2) mymap.begin() возвращает итератор, правильно?

Проблема в том, что не могу "срезать". Всё начинается с того, что есть итератор, указывающий на mymap.begin(), и есть итератор, указывающий на mymap.end()
Начинаю писать двоичный поиск:
while (iter1->first < iter2->first) // пока отрезок не пуст
а вот тут нужен итератор, указывающий на... средний элемент в mymap.

Т.е. когда мы, например, работаем с одномерным int массивом a размера N, у которого всё отсортировано, там всё просто... L=0, R=N-1 – индексы левый и правый соответственно; X - то, что в нём найти нужно, и пишем
C++
1
2
3
4
5
6
7
while (L<=R) {
   int M = (L+R)/2 ;  // индекс середки
   if (a[M] == X) return M; 
   if (a[M]>X) R=M-1; 
   else L=M+1; 
   // и т.п. всё легко
   }
А как быть в моей ситуации? Что в данном случае "индекс середки"? Как обратиться к элементу, лежащему между? Короче, суть в том, что непонятно, как обратиться "по индексу" к элементу map (который <string, string>). Я ж не могу написать (iter1->first + iter2->first)/2 – тут же не численные значения, а строки...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.03.2013, 14:20
Ответы с готовыми решениями:

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

Двоичный поиск
Формат входных данных В первой строке входных данных содержатся натуральные числа N и K (1≤N,K≤100000). Во второй строке...

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

6
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
03.03.2013, 14:45
какая-то странная задача. в мапине уже есть функция find, которая и пользуется тем, что в мапине все отсортировано. она возвращает нужный итератор, если найдет что-то. или она вас чем-то не устраивает?
0
127 / 131 / 11
Регистрация: 25.12.2011
Сообщений: 443
03.03.2013, 14:56
Цитата Сообщение от Delmellor Посмотреть сообщение
мне нужно реализовать двоичный поиск в map по ключам
А зачем, если уже есть std::map::find? К деталям реализации map доступа нет, так что итераторами можно только последовательно получать элементы.
0
Эксперт С++
1675 / 1047 / 174
Регистрация: 27.09.2009
Сообщений: 1,945
03.03.2013, 14:57
Элементы в map расположены в дереве, так что несмотря на упорядоченность, о произвольном доступе можно забыть. Для поиска следует применять метод find - в конце концов, map именно для того и придумывали, чтобы самому поиски не писать.
0
1 / 1 / 0
Регистрация: 18.11.2012
Сообщений: 37
03.03.2013, 17:23  [ТС]
Ммм... спасибо за ответы; не знал про find.
Но тема не исчерпана. Ведь для find'a нужен конкретный ключ, который совпадает с ключом map элемента, на который возвращается итератор. А у меня его (ключа) нет... мне нужен элемент строго между итераторами; ведь в этом суть двоичного поиска! – постоянно сокращать отрезок.
Просто тогда расширю вопрос... Как реализовать двоичный поиск вообще в такой ситуации?

Обновлено: прочитал посты выше внимательнее... Понимаете, у меня задача состоит в том, чтобы использовать именно двоичный поиск; map использовать или не map – неважно; важна реализация двоичного поиска. А я выбрал для этого map, потому что задача про отсортированную по алфавиту телефонную книгу, в которой нужно использовать двоичный поиск, чтобы найти абонентов по заданному номеру.
0
127 / 131 / 11
Регистрация: 25.12.2011
Сообщений: 443
03.03.2013, 17:32
Цитата Сообщение от Delmellor Посмотреть сообщение
важна реализация двоичного поиска
Тогда тебе нужно брать контейнер с RandomAccessIterator, а map для этого не подходит. Можно взять std::vector, предварительно самому отсортировав его через std::sort.
1
Эксперт С++
1675 / 1047 / 174
Регистрация: 27.09.2009
Сообщений: 1,945
03.03.2013, 19:51
Цитата Сообщение от Delmellor Посмотреть сообщение
Понимаете, у меня задача состоит в том, чтобы использовать именно двоичный поиск
Если задача в том, чтобы двоичный поиск использовать, то map и find подходят как нельзя более кстати. Если же требуется его реализовать самостоятельно, то следуй дельному совету kamre.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.03.2013, 19:51
Помогаю со студенческими работами здесь

Двоичный поиск
Добрый день. Помогите найти ошибку в двоичном поиске. Вот код: #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; ...

Двоичный поиск
Помогите пожалуйста с двоичным поиском: нужно найти абитуриента с 287 баллами методом двоичного поиска.. #include &lt;iostream.h&gt; ...

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

Двоичный поиск
Требуется найти в массиве элементы которые повторяются и элементы которые присутствуют единожды. #include &lt;stdafx.h&gt; #define N...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru