Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 24.05.2021
Сообщений: 13

Поиск образца в тексте

16.06.2022, 20:19. Показов 1104. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан текст, состоящий из строчных латинских букв, и шаблон, состоящий из строчных латинских букв и знаков вопроса. Знак вопроса может обозначить любую букву. Например, строки "abaca" и "??ac?" равны, а "aba" и "?c?" — нет.

Ваша задача — вывести все позиции вхождения шаблона в текст.



Интересна реализация проверки каждого символа в строке, не могу додуматься


input.txt
abacaba
a?a

output.txt
1 3 5

input.txt
pamparamparampampam
pa?

output.txt
1 4 9 14 17

input.txt
pamparamparampampam
pam

output.txt
1 14 17
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.06.2022, 20:19
Ответы с готовыми решениями:

Поиск образца в тексте
Дан текст, состоящий из строчных латинских букв, и шаблон, состоящий из строчных латинских букв и знаков вопроса. Знак вопроса может...

Поиск образца в тексте
Дан текст, состоящий из строчных латинских букв, и шаблон, состоящий из строчных латинских букв и знаков вопроса. Знак вопроса может...

Поиск образца в тексте
Найти все вхождения подстроки Pattern в строку Text. Вход. Строки Pattern и Text Выход Все индексы i строки Text, начиная с которых...

1
 Аватар для iLinks
800 / 458 / 237
Регистрация: 03.01.2017
Сообщений: 1,339
17.06.2022, 15:52
Лучший ответ Сообщение было отмечено SSkrrrrra как решение

Решение

SSkrrrrra, если не регуляркой, то например так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
List<(string, string)> collection = new List<(string, string)>()
{
    ("abacaba","a?a"),
    ("pamparamparampampam", "pa?"),
    ("pamparamparampampam", "pam")
};
foreach (var input in collection)
{
    string text = input.Item1;
    string pattern = input.Item2;
    for (int i = 0; i < text.Length; i++)
    {
        if (i + pattern.Length - 1 <= text.Length - 1)
        {
            string patternSubstring = string.Empty;
            for (int j = 0; j < pattern.Length; j++)
            {
                if (pattern[j] == '?')
                {
                    patternSubstring += text[i + j].ToString();
                }
                else
                {
                    patternSubstring += pattern[j].ToString();
                }
            }
            var test = text.Substring(i, pattern.Length);
            if (text.Substring(i, pattern.Length).Equals(patternSubstring))
            {
                Console.Write(i + 1 + " ");
            }
        }
    }
    Console.WriteLine();
}
Console.ReadLine();
Вывод:
Code
1
2
3
1 3 5
1 4 9 14 17
1 14 17
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.06.2022, 15:52
Помогаю со студенческими работами здесь

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

Поиск образца в тексте/ Найти все вхождения строки Pattern в строку Tex
Помогите пожалуйста Поиск образца в тексте Найти все вхождения строки Pattern в строку Text. Вход. Строки Pattern и Text. Выход....

Найти в тексте все вхождения данного образца
Здравствуйте! Очень нужна помощь. Задание: найти в тексте все вхождения данного образца. То есть это просто поиск подстроки в строке?...

Найти в тексте все вхождения данного образца
Буду рад любой помощи вообще непонятна сама организация поиска, помогите пожалуйста

Поиск вхождения вектора-образца в каждую из строк двумерной матрицы
Поиск вхождения вектора-образца в каждую из строк двумерной матрицы. Результатом должен быть массив размеров N*2 со списком индексов,...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru