Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17

Программа для подсчета уровня частоты вхождений слов

24.03.2016, 19:44. Показов 1547. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
#include <string>
#include <map>
#include <fstream>
 
using namespace std;
 
int main()
    {
    map <string,int> words;
    
    ifstream in;
    in.open("in.txt");
    
    string word;
    
    while (in>>word)
    {
        words[word]++;
    }
    
    ofstream out;
    out.open("out.txt");
    
    int count = 0;
    
    map <string,int>::iterator cur;
    
    out<<"Words count:"<<endl;
    
    for (cur=words.begin();cur!=words.end();cur++)
    {
        out<<(*cur).first<<": "<<(*cur).second<<endl;count+=(*cur).second;
    }
    
    out<<"Words percenc:"<<endl;
    
    for (cur=words.begin();cur!=words.end();cur++)
    {
        out<<(*cur).first<<": "<<(float)((float)(*cur).second/(float)count)*100<<"%"<<endl;
    }
    
    return 0;
}
Подскажите пожалуйста, как сделать так что бы выводило в файл только русские слова (а не всё подряд)
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.03.2016, 19:44
Ответы с готовыми решениями:

Программа для подсчета уровня частоты вхождений слов
Есть программа для вывода слов из текстового файла, и подсчета их количества. Проблема в том что она выводит всё подряд, а требуется только...

Программа для подсчета частоты вхождения слов
Программа считает частоту вхождений слов, но есть небольшой нюанс. Слова типа (&quot;как-то&quot;) выводит как два отдельных слова, как и...

Программа для подсчета частоты вхождения слов
Доброго времени суток. Недавно помогли &quot;сворганить&quot; програмку для подсчета частоты вхождения слов из текстового файла: #include...

11
 Аватар для yrceus
88 / 88 / 80
Регистрация: 25.08.2013
Сообщений: 337
24.03.2016, 21:01
Кодировка 1251, можно посмотреть в каждом слове каждый символ и если он удовлетворяет диапазону значений кириллических символов от 'A' до 'я', то записывать это слово.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
#include <string>
#include <vector>
#include <Windows.h>
using namespace std;
 
int main() {
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);   
    vector<string> sh{ "Аббра", "Abbra" }; 
    for (auto &word : sh) {
        bool flag(true);
        for (auto &sym : word) 
            if (sym < -64 || sym > -1)
                flag = false;
        if (flag)
            cout << word << endl;
    }
    return 0;
}
0
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17
24.03.2016, 21:16  [ТС]
а возможно ли это реализовать через ф-цию isalpha?
0
 Аватар для yrceus
88 / 88 / 80
Регистрация: 25.08.2013
Сообщений: 337
24.03.2016, 22:15
Сомневаюсь, но в целом наверняка есть другие варианты, через функции...
0
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17
24.03.2016, 23:34  [ТС]
yrceus, я попробовал скомпоновать 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
#include <iostream> 
#include <string> 
#include <vector> 
#include <map> 
#include <Windows.h> 
#include <fstream> 
 
using namespace std; 
 
int main() 
{ 
map <string, int> words; 
 
ifstream in; 
in.open("file.txt"); 
 
string word; 
 
while (in » word) 
{ 
words[word]++; 
} 
 
ofstream out; 
out.open("out.txt"); 
 
int count = 0; 
 
map <string, int>::iterator cur; 
 
out « "Words count:" « endl; 
 
for (cur = words.begin(); cur != words.end(); cur++) 
{ 
out « (*cur).first « ": " « (*cur).second « endl; count += (*cur).second; 
} 
 
SetConsoleCP(1251); 
SetConsoleOutputCP(1251); 
 
vector<pair<string, size_t» sh(words.begin(), words.end()); 
 
for (auto &word1 : sh) { 
bool flag(true); 
for (auto &sym : word) 
if (sym < -64 || sym > -1) 
flag = false; 
if (flag) 
 
for (auto &_pair : sh) 
cout « _pair.first « " = " « _pair.second « endl; 
} 
system("pause"); 
return 0; 
}
0
 Аватар для yrceus
88 / 88 / 80
Регистрация: 25.08.2013
Сообщений: 337
25.03.2016, 00:01
Лучший ответ Сообщение было отмечено example11 как решение

Решение

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 <string>
#include <map>
#include <fstream>
#include <Windows.h>
using namespace std;
 
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    map <string, int> words;
    ifstream in("in.txt");
    string word;
    while (in >> word)  
        words[word]++;
    ofstream out("out.txt");
    int count = 0;
    out << "Words count:" << endl;
    for (map <string, int>::iterator cur = words.begin(); cur != words.end(); cur++)    {       
        bool flag(true);
        for (auto &sym : cur->first)
            if (sym < -64 || sym > -1)
                flag = false;
        if (flag)
            out << (*cur).first << ": " << (*cur).second << endl; count += (*cur).second;
    }
    out << "Words percenc:" << endl;
    for (map <string, int>::iterator cur = words.begin(); cur != words.end(); cur++)    {
        bool flag(true);
        for (auto &sym : cur->first)
            if (sym < -64 || sym > -1)
                flag = false;
        if (flag)
            out << (*cur).first << ": " << (static_cast<float>((*cur).second) / count) * 100 << "%" << endl;
    }
    return 0;
}
1
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17
25.03.2016, 15:48  [ТС]
спасибо большое.
0
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17
31.03.2016, 21:40  [ТС]
yrceus, Возможна ли сортировка для программы выше ? Если да, то как?
class GreaterSizeBup
{
public:
GreaterSizeBup() {}
bool operator()(const pair<string, size_t> &s1, const pair<string, size_t> &s2) const
{

return s2.second < s1.second;
}
};

class GreaterSizeBdown
{
public:
GreaterSizeBdown() {}
bool operator()(const pair<string, size_t> &s1, const pair<string, size_t> &s2) const
{
return s2.first.size() > s1.first.size();
}
};

/***************************************/



vector<pair<string, size_t>> line(words.begin(), words.end());
sort(line.begin(), line.end(), GreaterSizeBup());

Возможна ли сортировка? Если да, то как?
0
 Аватар для yrceus
88 / 88 / 80
Регистрация: 25.08.2013
Сообщений: 337
31.03.2016, 21:44
Сортировка строк? Так они же сортируются? Или тебе по длине нужно?
0
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17
31.03.2016, 21:53  [ТС]
Нужна сортировка по количеству вхождений, то есть по значениям int
0
 Аватар для yrceus
88 / 88 / 80
Регистрация: 25.08.2013
Сообщений: 337
31.03.2016, 23:18
Поменять местами тип ключа и значения в map? И попутно пробежаться по коду заменив first на second и наоборот.
0
0 / 0 / 0
Регистрация: 09.03.2016
Сообщений: 17
11.04.2016, 21:37  [ТС]
yrceus, Привет, всё ещё пытаюсь разобрать программу. Подскажи как подключить функцию проверки на принадлежность символов к моей программе. Вот сама функция.
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
// Если x принадлежит строке A, возвращается номер элемента, равного x;
    // Если x == L'-' возвращается 0;
    // Если x не принадлежит A и x != L'-', возвращается -1.
    CharType AbcToInd(std::wstring& A, wchar_t s) {
        if ( s == L'-' ) return s;
        for ( size_t i = 0; i < A.size(); ++i ) if ( s == A[i] ) return s;
        return L' ';
    }
 
 
 
// Глобальные переменные
    std::wstring ABC;
    sfat::VecWCP MainList;
 
    // Глобальные функции
    
    // Функция выполняет преобразование строки String^ S в строку std::wstring& w
    void String_to_wstring(std::wstring& w, System::String^ S) {
        w.resize(S->Length);
        for ( size_t i = 0; i < w.size(); ++i ) w[i] = S->default[i];
    }
    // Функция выполняет преобразование строки std::wstring& w в строку String^ S
    String^ wstring_to_String(std::wstring& w) {
        return gcnew String(w.c_str());
    }
 
 
 
// Функция для загрузки алфавита из файла
bool MFUnit::LoadABC() {
    if ( AbcFile == String::Empty )
        AbcFile = System::IO::Directory::GetCurrentDirectory() + L"\\Alphabet.txt";
    try {
        IO::StreamReader^ AbcReader = 
            gcnew System::IO::StreamReader(AbcFile, CurEnc);
        String_to_wstring(ABC, AbcReader->ReadLine());
        AbcReader->Close();
    }
    catch ( System::Exception^ St01 ) {
        MessageBox::Show(St01->Message,
            "Невозможно загрузить алфавит", MessageBoxButtons::OK,
            MessageBoxIcon::Exclamation);
        return false;
    }
    return true;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.04.2016, 21:37
Помогаю со студенческими работами здесь

Напишите программу для подсчета числа вхождений заданного слова из файла
&quot;Напишите программу для подсчета числа вхождений заданного слова из файла&quot;. (упражнение из Эккеля) в общем, суть понял, но результат...

Программа подсчета слов, база данна
#include &quot;stdafx.h&quot; #define YES 1 #define NO 0 main() /* count lines, words, chars in input */ { int c, nl,...

Программа подсчета символов и слов в минуту
Пытаюсь написать программу для подсчёта слов и символов в минуту Но проблема в том , что не знаю как устроен таймер, как сделать так,...

Программа подсчета количесва указанных слов в тексте
#include &quot;stdafx.h&quot; #include &lt;fstream&gt; #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;conio.h&gt; using namespace std; int...

Программа подсчета строк, слов и символов не выводит результат
Читаю книгу по с++ и там есть пример такой задачи. Когда запускаю ее то она ничего не выводит. В чем проблема? #include...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru