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

Поиск всех вхождений подстроки

02.12.2019, 20:35. Показов 1953. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать в int main() код, который будет выводить на экран результат (res) функции поиска, но чтобы выводило все знач
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include "pch.h"
#include <iostream>
#include <vector>
#include <string>
using namespace std;
 
int DirectSearch(char *string, char *substring) {
  int sl, ssl;
  int res = -1;
  sl = strlen(string);
  ssl = strlen(substring);
  if (sl == 0)
    cout << "Неверно задана строка\n";
  else if (ssl == 0)
    cout << "Неверно задана подстрока\n";
  else
    for (int i = 0; i < sl - ssl + 1; i++)
      for (int j = 0; j < ssl; j++)
        if (substring[j] != string[i + j])
          break;
        else if (j == ssl - 1) {
          res = i;
          break;
        }
  return res;
}
 
int KMPSearch(char *string, char *substring) {
  int  sl, ssl;
  int res = -1;
  sl = strlen(string);
  ssl = strlen(substring);
  if (sl == 0)
    cout << "Неверно задана строка\n";
  else if (ssl == 0)
    cout << "Неверно задана подстрока\n";
  else {
    int  i, j = 0, k = -1;
    int  *d;
    d = new int[1000];
    d[0] = -1;
    while (j < ssl - 1) {
      while (k >= 0 && substring[j] != substring[k])
        k = d[k];
      j++;
      k++;
      if (substring[j] == substring[k])
        d[j] = d[k];
      else
        d[j] = k;
    }
    i = 0;
    j = 0;
    while (j < ssl && i < sl) {
      while (j >= 0 && string[i] != substring[j])
        j = d[j];
      i++;
      j++;
    }
    delete[] d;
    res = j == ssl ? i - ssl : -1;
  }
  return res;
}
int main()
{
  char string[1024];
  cout << "Enter String:" << endl;
  cin.getline(string,1024);
 
  char substring[1024];
  cout << "Enter Substring:" << endl;
  cin.getline(substring, 1024);
 
  //cout << "\n" << "Res = " << KMPSearch(string, substring);---выводит одно значение res ( последние)
 
Надо сделать чтобы выводило все.Пример: string: abcabc, substring: abc ; res: 0,3 ...а выводит только 3
  
  //std::vector<int> res = KMPSearch(string, substring);
 
  /*for (std::vector<int>::const_iterator it = res.begin(); it != res.end(); ++it)
    std::cout << *it << std::endl;*/
  return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.12.2019, 20:35
Ответы с готовыми решениями:

Функция замены всех вхождений подстроки
Необходимо написать функцию типа функции PHP str_replace , которая возвращает строку, в которой все вхождения search заменены на replace....

Как ускорить работу (поиск вхождений подстроки)?
//подсчет kf int NumberKF(string &amp;P, vector&lt;string&gt; &amp; F, const int f){ int kf =0; for(size_t i = 0; i &lt; f; ++i){ //обход по...

Поиск всех вхождений шаблона в строку
Здравствуйте,хотела к вам обратиться за помощью..в файле t.txt есть строка из символов букв латинского алфавита,длиной до 100000 знаков....

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.12.2019, 20:35
Помогаю со студенческими работами здесь

Написать программу, которая выводит позиции всех вхождений гена в геном (поиск гена)
Задан геном некоторого организма (последовательность букв A T G C (аденин, тимин, гуанин, цитозин). Также задан некоторый ген (тоже...

Подсчет вхождений подстроки в строку
Здравствуйте, помогите найти ошибку, в файле есть строки например S1gfgd S2vsdfvbf S1ffgv необходимо подсчитать сколько раз...

Подсчет количества вхождений заданной подстроки
char s; cin.getline(s,255); char m; cin.getline(m,255); cout&lt;&lt;s&lt;&lt;endl; int...

Определить число вхождений подстроки в строку
Не нашел того что мне нужно, поэтому задам вопрос. Входные данные: длина строки сама строка Выходные данные: максимальное...

Найти количество и места вхождений подстроки в строку
Всем привет, есть задача, где нужно найти количество и места вхождений подстроки в строку, но она немного не стандартна, то есть в...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru