Форум программистов, компьютерный форум CyberForum.ru

Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице - C++

Восстановить пароль Регистрация
 
taeas1995
6 / 2 / 0
Регистрация: 19.01.2012
Сообщений: 157
07.09.2014, 22:56     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #1
У меня есть этот алгоритм. Кто знает, как усовершенствовать его, чтобы он искал символьную подматрицу m * m в символьной матрицы n * n, при котором m <= n?

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
#include "stdafx.h"
#include<iostream>
#include<cstring>
#include<cstdio>
#define d 256                
using namespace std;
void search(char *txt , char *pat , int q){
int m=strlen(pat);
int n=strlen(txt);
 
int i,j;
int p=0;                 
int t=0;               
int h=1;                      
 
 
for(i=0;i<m-1;i++){
h=(d*h)%q;
}
 
 
 
for(i=0;i<m;i++){
p=(d*p+pat[i])%q;
t=(d*t+txt[i])%q;
}
 
for(i=0;i<=n-m;i++){
 
 
 
if(t==p){
for(j=0;j<m;j++){
if(txt[i+j]!=pat[j]) {
break;
}
}
if(j==m) cout<<"Stroka znaidena v ryadku: "<<i<<endl;
}
 
 
if(i<n-m){
t = (d*(t - txt[i]*h) + txt[i+m])%q;
 
 
if(t < 0)
t = (t + q); 
}
}
}
 
int main(){
char a[500],b[500];
cout<<"Vvedit text:"<<endl;
cin.getline(a,500);
cout<<"Vvedit stroku dlya poshuku:"<<endl;
cin.getline(b,500);
int q=7;                     
search(a,b,q);  
system("pause");
return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.09.2014, 22:56     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице
Посмотрите здесь:

C++ (ищу алгоритм) Хопкрофта-Карпа
Алгоритм шифрования Рабина C++
как работает эта программа(Алгоритм Рабина-Карпа с++)??? C++
Найти в прямоугольной матрице подматрицу из единиц максимального размера. C++
Реализация алгоритма Рабина-Карпа для двух однонаправленных линейных списков C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
gazlan
2855 / 1803 / 271
Регистрация: 27.08.2010
Сообщений: 4,883
Записей в блоге: 1
07.09.2014, 23:58     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #2
Цитата Сообщение от taeas1995 Посмотреть сообщение
усовершенствовать
Если m и n произвольны, то задача несводима к поиску одиночной подстроки, и требует множественного поиска. Усовершенствовайте Aho-Corasick.

Взгляните еще на организацию логических условий в сигнатурах ClamAV. (3.5.5 Logical signatures)
taeas1995
6 / 2 / 0
Регистрация: 19.01.2012
Сообщений: 157
08.09.2014, 18:30  [ТС]     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #3
Тогда как сделать множественный поиск? Помогите пожалуйста

Добавлено через 18 минут
очень нужно на завтра(
gazlan
2855 / 1803 / 271
Регистрация: 27.08.2010
Сообщений: 4,883
Записей в блоге: 1
08.09.2014, 18:37     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #4
  • разбить m*m матрицу на строки
  • добавить эти строки в словарь AC
  • выполнить поиск (с перекрытием)
  • вычеркнуть из списка найденных те, чьи позиции не начинаются в узлах подсетки m*m наложенной на сетку n*n (в первом столбце)
  • убедиться, что осталось ровно m строк в узлах с шагом n (or search fail)
  • Profit!

Иными словами, убедиться, что найдены все строки из матрицы m*m и что они расположены в матрице n*n с таким шагом, что образуют квадратную подматрицу.
taeas1995
6 / 2 / 0
Регистрация: 19.01.2012
Сообщений: 157
08.09.2014, 19:00  [ТС]     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #5
А когда m и n не произвольны? Мне нужно программно реализовать, на теории не знаю( (когда m и n не произвольны)
gazlan
2855 / 1803 / 271
Регистрация: 27.08.2010
Сообщений: 4,883
Записей в блоге: 1
08.09.2014, 19:31     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #6
Цитата Сообщение от taeas1995 Посмотреть сообщение
А когда m и n не произвольны?
Подумав, решил, что это не сильно поможет: развертывание n*n матрицы в линию с выбрасыванием "лишних" столбцов даст слишком большое (n-m+1) число вариантов, в которых все равно придется проверять кратность найденного смещения m.

Если n невелико, можно использовать построчный просмотр: ищете первую строку из m в строках из n. Если число оставшихся в n строк меньше (m-1) - поиск неудачен, выход. Повторяете для всех строк из m. Смещение в строке n для найденных строк из m должно совпадать (несовпадающие вычеркиваете из списка) и их должно быть ровно m, иначе поиск неудачен.

В любом случае, самый трудоемкий момент - выбор из всего списка найденных строк только тех, что образуют "внутренний квадрат" m*m
taeas1995
6 / 2 / 0
Регистрация: 19.01.2012
Сообщений: 157
08.09.2014, 19:52  [ТС]     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #7
Можете тогда написать (дописать в программе) как построчный просмотр сделать, очень нужно..
gazlan
2855 / 1803 / 271
Регистрация: 27.08.2010
Сообщений: 4,883
Записей в блоге: 1
08.09.2014, 20:09     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #8
Цитата Сообщение от taeas1995 Посмотреть сообщение
как построчный просмотр
Так и делайте, как сказано в #6. Подойдет любой алго точного поиска, даже ваш Рабина-Карпа (если он работает).
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.09.2014, 20:17     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице
Еще ссылки по теме:

Найти в матрице квадратную подматрицу C++
Алгоритм Рабина-Карпа C++
Задача: плохая подстрока. Усовершенствовать алгоритм C++

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

Или воспользуйтесь поиском по форуму:
taeas1995
6 / 2 / 0
Регистрация: 19.01.2012
Сообщений: 157
08.09.2014, 20:17  [ТС]     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице #9
Мне помогли сделать этот алгоритм, я только начинаю изучать язык c++. Буду очень благодарен, если напишите код для построчного просмотра.
Yandex
Объявления
08.09.2014, 20:17     Усовершенствовать алгоритм Рабина-Карпа, чтобы он искал символьную подматрицу в символьной матрице
Ответ Создать тему
Опции темы

Текущее время: 01:24. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru