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

Алгоритм прямого поиска. Реализация на С++ - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.83
trunks1994
0 / 0 / 0
Регистрация: 11.01.2013
Сообщений: 12
11.05.2013, 16:13     Алгоритм прямого поиска. Реализация на С++ #1
может кто-то написать алгоритм прямого поиска на С++?
очень надо...
суть поиска такова:

Алгоритм прямого поиска


Идея алгоритма:
1. I=1,
2. сравнить I-й символ массива T с первым символом массива W,
3. совпадение → сравнить вторые символы и так далее,
4. несовпадение → I:=I+1 и переход на пункт 2,

Условие окончания алгоритма:
1. подряд М сравнений удачны,
2. I+M>N, то есть слово не найдено.

Сложность алгоритма:
Худший случай. Пусть массив T→{AAA….AAAB}, длина │T│=N, образец W→{A….AB}, длина │W│=M. Очевидно, что для обнаружения совпадения в конце строки потребуется произвести порядка N*M сравнений, то есть O(N*M).

Недостатки алгоритма:
1. высокая сложность — O(N*M), в худшем случае – Θ((N-M+1)*M);
2. после несовпадения просмотр всегда начинается с первого символа образца и поэтому может включать символы T, которые ранее уже просматривались (если строка читается из вторичной памяти, то такие возвраты занимают много времени);
3. информация о тексте T, получаемая при проверке данного сдвига S, никак не используется при проверке последующих сдвигов.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.05.2013, 16:13     Алгоритм прямого поиска. Реализация на С++
Посмотрите здесь:

C++ Реализация Поиска В Файле
C++ Реализация бинарного дерева поиска
Реализация алгоритма поиска подстрок чжу такаоки на c++ C++
C++ Реализация словаря в двоичном дереве поиска
Реализация словаря в двоичном дереве поиска C++
Реализация поиска в глубину C++
Реализация поиска мостов на графе C++
Реализация бинарного поиска C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
xtorne21st
интересующийся
300 / 271 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
11.05.2013, 17:33     Алгоритм прямого поиска. Реализация на С++ #2
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
#include <iostream>
#include <cstring>
 
char* userStrstr(const char* haystack, char* needle)
{
    for (const char* hp = haystack; hp != haystack + strlen(haystack); ++hp)
    {
        const char* np = needle;
        const char* tmp = hp;
        for ( ; np != needle + strlen(needle); ++np)
        {
            if (*tmp != *np)
            {
                break;
            }
            else
            {
                ++tmp;
            }
        }
        if (np == needle + strlen(needle))
        {
            return needle;
        }
    }
    return 0;
}
 
int main()
{
    char first[] = "Hello, dyadya Vasya!";
    char second[] = "Vasya";
 
    if (userStrstr(first, second))
    {
        std::cout << second << std::endl;
    }
}
Yandex
Объявления
11.05.2013, 17:33     Алгоритм прямого поиска. Реализация на С++
Ответ Создать тему
Опции темы

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