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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Даны текстовые файлы F и G. Переписать в файл Q все слова, встречающиеся и в F, и в G http://www.cyberforum.ru/cpp-beginners/thread1153336.html
Даны текстовые файлы F и G. Переписать в файл Q все слова, встречающиеся и в F, и в G Чем быстрее, тем лучше) Начало вроде написал, но застрял на разделении на слова и их сравнении. Простым...
C++ Неправельно работает функция шифрование Помогите разобоаться! Метод шифрование простыми вертикальными перестановками. Проблема в построение квадрата символов т.е. не все символы выводит , и в конце квадрата должны добавляться символы '*'... http://www.cyberforum.ru/cpp-beginners/thread1153335.html
Как проверить массив из char на пустоту? C++
после чсла выводит буквы М, в том месте где пустые значения, как сделать чтобы они не выводились? number != '\0' - не помогает, NULL тоже char number; cin>>number; for (int i = 0; i < 100;...
Чтение слов из файла и запись в бинарное дерево C++
Нужно произвести чтение слов из файла и записать их в бинарное дерево. Я написал следующую функцию добавления. Как сделать так, чтобы он записывал все слова в дерево? У меня получается, что он...
C++ Получить зависимость усреднённых затрат машинного времени от длины массива http://www.cyberforum.ru/cpp-beginners/thread1153305.html
В массивах нулевые элементы – удалять, а положительные – располагать по возрастанию методом пузырька. Во избежание избыточного просмотра сохранять индекс последнего обмена. Получить зависимость...
C++ Текст в графическом режиме Мне нужно ввести строку в графическом режиме. При этом для остального текста я пользуюсь settextstyle(). Есть ли возможность вводить строку в нужном месте экрана и с необходимым увеличением? Ниже мой... подробнее

Показать сообщение отдельно
nightgrive
Сообщений: n/a

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

21.04.2014, 17:51. Просмотров 748. Ответов 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);
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru