Модераторы: korob2001, ginnie

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Алгоритм поиска, Эффективный алгоритм поиска 
:(
    Опции темы
tishaishii
Дата 23.3.2007, 22:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Создатель
***


Профиль
Группа: Завсегдатай
Сообщений: 1262
Регистрация: 14.2.2006
Где: Москва

Репутация: 4
Всего: 8



Когда-то я разработал алгоритм для поиска наиболее точных шаблонов для многих строк.

Рассмотрим на 2х, т.к. писать много, но работает для многих.
Есть строки A="abckd" и B="dacbdaf".
Представляешь строки в виде массивов символов, нумеруешь каждый символ.
Составляешь матрицу типа:
Код
        1    2    3    4    5
        a    b    c    k    d
1    d    0    0    0    0    1
2    a    1    0    0    0    0
3    c    0    0    1    0    0
4    b    0    1    0    0    0
5    d    0    0    0    0    1
6    a    1    0    0    0    0
7    f    0    0    0    0    0

Т.е., например, A по горизонтали, B - по вертикали.
1 - совпадение символов в строках, 0 - сам понимаешь.

Удаляешь все строки и столбцы (с номерами), в которых нет единиц. Нумерацию символов обязательно сохраняешь.
Код
        1    2    3    5
        a    b    c    d
1    d    0    0    0    1
2    a    1    0    0    0
3    c    0    0    1    0
4    b    0    1    0    0
5    d    0    0    0    1
6    a    1    0    0    0


Рассматриваешь получившуюся матрицу посимвольно с точки зрения A. Получается, что A(1)="a" принадлежит B(2, 6), A(2) принадлежит B(4), ...
Т.е. строишь списки:
Код
1:{2,6}
2:{4}
3:{3}
5:{1,5}

Т.е., по-синтаксису выше, A(i):{B(j[k[u]])}, а, по-математике, A(i) принадлежит {B(j[k[u]])}.
Вот надо искать самые длинные списки таких B[j[k[u]]], что B[j[k[u]]]<B[j[k[u+1]]].
Ну, сложно выразился. Посмотри глазами. Надо, чтобы позиция каждой предыдущей буквы из B была меньше следующей.

Посмотри глазами (ещё раз).
Предполагаемое ре

Добавлено @ 22:25 
Глюк темплейта форума, не могу редактировать сообщение.
Ошибка в формулировке:
Цитата
Если строк много, то следует пересмотреть всевозможные варианты без повторов пар строк.

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

Это сообщение отредактировал(а) tishaishii - 23.3.2007, 22:21
PM MAIL ICQ Skype   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Perl"
korob2001
sharq
  • В этом разделе обсуждаются общие вопросы по языку Perl
  • Если ваш вопрос относится к системному программированию, задавайте его здесь
  • Если ваш вопрос относится к CGI программированию, задавайте его здесь
  • Интерпретатор Perl можно скачать здесь ActiveState, O'REILLY, The source for Perl
  • Справочное руководство "Установка perl-модулей", можно скачать здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, korob2001, sharq.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Perl: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0608 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.