Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
3 / 3 / 2
Регистрация: 05.12.2011
Сообщений: 51

Поиск подстроки с помощью BinarySearch

07.11.2015, 17:23. Показов 732. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!

Такая задача завела меня в тупик. Есть массив строк, отсортированный лексикографически. Хочу в его элементах найти точную подстроку. Т.к. массив отсортирован, была мысль использовать BinarySearch, но не пойму, как его использовать в моей ситуации.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private void Search()
        {
            string[] stringArray = new[] {"aaa", "aab", "aba", "baa", "bba", "bbb"};
 
            string pattern1 = "baa";
            int index1 = Array.BinarySearch(stringArray, pattern1);
            Console.WriteLine(index1.ToString()); //Консоль: 3
 
 
            string pattern2 = "ba";
            int index2 = Array.BinarySearch(stringArray, pattern2);
            Console.WriteLine(index2.ToString()); //Консоль: -1 
 
            //Я хочу, чтобы во втором случае вывелось 2 (индекс 1-го элемента с данной подстрокой)
        }
Подскажите, пожалуйста, как мне организовать такой поиск?

Всем спасибо за помощь!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.11.2015, 17:23
Ответы с готовыми решениями:

Поиск подстроки с помощью регулярного выражения
Дан текстовый файл, имеющий структуру "Фамилия И.О. - улица - номер дома - квартира - номер телефона". Вывести фамилии всех абонентов...

Поиск подстроки с помощью регулярного выражения
Есть текст string'а. Стоит задача, найти и вынести в отдельную переменную нужную подстроку. Подстрока начинается с "<img...

Удаление подстроки с помощью регулярных выражений
using System; using System.Collections.Generic; using System.Linq; using System; using System.Collections.Generic; using...

2
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
08.11.2015, 10:46
spirart, Если подстрока может быть в любой позиции в слове, то BinarySearch вам никак не поможет и сортировка - тоже. Ведь строки содержащие "ba" могут быть и в начале списка и в конце, и где угодно.
0
Неадекват
 Аватар для freeba
1501 / 1237 / 248
Регистрация: 02.04.2010
Сообщений: 2,807
08.11.2015, 11:45
Бинарный поиск никак не поможет в поиске подстрок. Воспользуйтесь одним из типовых алгоритмов.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.11.2015, 11:45
Помогаю со студенческими работами здесь

Выделить подстроки из строки с помощью RegEx
Есть строка string text = @"hgdjhgdjhgds C:\temp\blablabla to D:\ololo" нужно выделить 2 подстроки так, чтобы text_ss1 =...

поиск подстроки
Постройте автомат для поиска подстроки Р=aabab и продемонстрируйте его работу на тексте Т=aaababaabaababaab. Нарисуйте схему переходов. Где...

Поиск подстроки
Написал прогу для поиска подстроки в строке. Все пояснение по роботе в комментах. Вопрос: почему программа выдает правильный результат...

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

Поиск подстроки в строке
Разрабатываю поиск переменных в протоколе текстового файла. Объясните на примере одной строки как это делается. Строка...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru