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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
nightgrive
Сообщений: n/a
#1

Найти количество вхождений каждого слова в файл - C++

21.04.2014, 17:51. Просмотров 747. Ответов 0
Метки нет (Все метки)

Есть файл, в нем определенный текст. Нужно найти сколько каждое слово встречается в файле...Начал писать, уже сделал чтобы разделяло на слова...но до истины увы дойти не могу...Помогите плиз)
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 #include <iostream>
#include <fstream>
using namespace std;
 
 
 
// Функция разбивает строку на слова, основываясь на строке разделителей
// Принимаемые параметры:
//  str - строка, которую необходимо разбить на слова
//  delims - строку, содержащая разделители
// Возвращаемое значение:
//  динамически выделенный массив слов (заканчивающийся нулевым указателем)
char **split_string(const char *str, const char *delims)
{
    // Предварительно считаем длину входной строки
    size_t str_len = strlen(str);
 
    // Счётчик слов в предложении
    size_t words_cntr = 1;
 
    // Результирующий массив слов
    char **words;
 
    // Счётчики циклов
    size_t i, j;
    size_t w;
 
    // Считаем количество слов
    for (i = 0; i < str_len; ++i)
        // Если очередной символ входной строки совпал с одним из разделителей
        if (strchr(delims, str[i]) != NULL)
            // Увеличиваем счётчик слов
            ++words_cntr;
 
    // Выделяем память под массив слов (размером количество слов + 1 элемент для
    // нулевого указателя - конца массива слов)
    words = (char **)malloc((words_cntr + 1) * sizeof(char *));
 
    // Сразу устанавливаем ограничитель массив слов
    words[words_cntr] = NULL;
 
    // Идём по всем символам строки
    for (i = 0, w = 0; i < str_len + 1; ++i)
    {
        // j служит для указания на конеч слова, i - на начало
        // Поиск конца слова начинаем с его начала
        j = i;
 
        // Пока не достигли конца строки или не нашли разделитель
        while (str[j] != '\0' && strchr(delims, str[j]) == NULL)
            // Говорим, что очередной символ строки входит в очередное слово
            ++j;
 
        // Выделяем память под очередное слово
        words[w] = (char *)malloc((j - i + 1) * sizeof(char));
 
        // Копируем слово в выделенную память
        strncpy(words[w], str + i, j - i);
        // Ограничиваем слово нуль-терминатором
        words[w++][j - i] = '\0';
 
        // Продолжаем поиск следующего слова с конца только что обработанного
        i = j;
    }
 
    // Возвращаем сформированный массив слов
    return words;
}
 
// Функция просто очищает память, выделенную под массив слов
void destroy_words(char **words)
{
    size_t i = 1;
 
    while (words[i - 1] != NULL)
        free(words[i++]);
 
    free(words);
}
 
int main(void)
{
      int length;
  char * buffer;
 
  ifstream is;
  is.open ("A:\\file.txt", ios::binary );
 
  // get length of file:
  is.seekg (0, ios::end);
  length = is.tellg();
  is.seekg (0, ios::beg);
 
  // allocate memory:
  buffer = new char [length];
 
  // read data as a block:
  is.read (buffer,length);
 
  is.close();
    
    const char *delims = " ";
 
    char **words = split_string(buffer, delims);
    
    size_t i;
 
    
    
    
    
    
    destroy_words(words);
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.04.2014, 17:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти количество вхождений каждого слова в файл (C++):

Определить количество вхождений каждого слова - C++
Проанализировать текстовый файл и посчитать, сколько раз в него входит каждое слово. Большие и маленькие буквы рассматриваем как одну и ту...

Определить количество вхождений каждого слова в заданную строку - C++
заданная строка. определить количество вхождения каждого слова в заданую строку. помогите,а то не могу понять почему не правельно...

Количество вхождений слова в файл - C++
Здравствуйте, уважаемые программисты! Нужна Ваша помощь, какая именно, речь пойдет далее:) Для начала я скажу, что программа делает, и...

Считать текст из файла, добавить в конце каждого предложения, количество вхождений в него заданного слова - C++
Вот задание: Написать программу, которая считывает текст из файла и выводит его на экран, добавляя после каждого предложения, сколько раз...

Найти в тексте количество вхождений определенного слова - C++
Ребята, приветствую! Мне необходимо загрузить из файла текст (перемешанный, т.е. и буквы, и цифры, и знаки препинания, и табуляции есть)....

Подсчитать количество вхождений слова «мама» в строку и вывести номера первых позиций этих вхождений - C++
Помогите исправить ошибку. Как вывести номера первых позиций вхождений слова мама? Подсчитать количество вхождений слова «мама» в строку...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.04.2014, 17:51
Привет! Вот еще темы с ответами:

Подсчёт вхождений каждого слова в текстовом файле[C++] - C++
Здравствуйте. Помогите пожалуйста. Требуется написать программу, которая бы из текстогого файла примерно такого типа: &quot;Эта строка...

Найти количество повторений каждого слова и удалить дубликаты слов - C++
В строке символов определить количество повторений каждого слова и удалить дубликаты слов. Слова отделяются пробелами. Как реализовать...

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

Подсчитать количество вхождений каждого символа в строку - C++
например у Вас есть строка: asddsg В выходной файле, куда Вы запишите результаты работы программы будет: a – 1 s – 2 d – 2 g – 1


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru