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

Поиск одинаковых слов в тексте - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
milkaaa
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 13
07.03.2014, 20:26     Поиск одинаковых слов в тексте #1
Решить на С++ с комментариями, если не сложно!

Дан файл, содержащий текст на русском языке. Найти слова, встречающиеся в каждом предложении, или сообщить, что таких слов нет.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.03.2014, 20:26     Поиск одинаковых слов в тексте
Посмотрите здесь:

поиск одинаковых слов на с++ C++
Как посчитать количество одинаковых слов в тексте? C++
C++ доработка кода на поиск повторяющихся слов в тексте
Поиск слов в тексте C++
C++ Поиск одинаковых слов в текстовых файлах
поиск слов в тексте C++
Масивы и строки: поиск и замена слов в тексте C++
Поиск слов в тексте C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
GuGo1991
267 / 261 / 93
Регистрация: 02.08.2012
Сообщений: 609
07.03.2014, 23:45     Поиск одинаковых слов в тексте #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
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 <iostream>
#include <fstream>
#include <windows.h>
 
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    int quant = 0, counter = 0;
    bool check = false;
    std::string s, str;
    std::ifstream wordsQuant("file.txt"); //Поток считывания
    while(wordsQuant >> str) //Считываем каждое слово из файла в str
    {
        quant++; //Инкрементируем количество
        s += str + " "; //"Приписываем" слово к строке s
    }
    
    std::string* words = new std::string[quant]; //Создаем строковый массив по размеру найденного количества
    char* chStr = new char[s.size() + 1]; //Создаём символьный массив по размеру s, плюс 1 для '\0'
    std::strcpy(chStr, s.c_str()); //Копируем s строку в массив chStr
    
    //Первое использование функции strtok(). В качестве указателя используем chStr.
    //Далее будем использовать NULL. Функция нужна для исключения запятых, точек, скобок и т. д.
    char* p = std::strtok(chStr, " ,.!?\"(){}:;");
    
    while(p != NULL)
    {
        words[counter] = p; //Сохраняем слово в массив
        counter++; //Увеличиваем значение индекса
        p = std::strtok(NULL, " ,.!?\"(){}:;");
    }
    
    counter = 0;
    //Поиск
    for(int i = 0; i < quant; i++)
    {
        s = words[i]; //Сохраняем слово в s
        for(int j = 0; j < quant; j++)
        {
            if(s.empty()) //Если слово пустое
                break;    //выходим из цикла
            if(s == words[j]) //Если нашлось подобное слово
            {
                counter++; //Увеличиваем счётчик
                words[j].clear(); //"Очищаем" элемент массива (т. е. слово)
            }
        }
        if(counter > 1) //Если счётчик больше одного, т.е. слово наткнулось не только на себя
        {
            check = true; //Меняем значение check на true
            std::cout << s << std::endl; //Печатаем слово
        }
        counter = 0; //Обнуляем счётчик
    }
    //Если check не изменился (false), значит повторяющихся слов нет
    (!check) ? std::cout << "\nNothing found\n\n"
             : std::cout << "\n";
    
    system("pause");
    return 0;
}
Yandex
Объявления
07.03.2014, 23:45     Поиск одинаковых слов в тексте
Ответ Создать тему
Опции темы

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