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

Записать в конец файла таблицу с указанием трех наиболее часто встречающихся слов

10.12.2018, 00:57. Показов 1994. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
2. Открыть текстовый файл в необходимом режиме (на чтение, на чтение и запись, на добавление). (В файле должно быть не менее 30 строк). Записать в конец этого же файла таблицу с указанием трех наиболее часто встречающихся слов и количества их повторений в строке.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.12.2018, 00:57
Ответы с готовыми решениями:

Записать в конец текстового файла таблицу с указанием трех наиболее часто встречающихся слов и их количества
Открыть текстовый файл в необходимом режиме (на чтение, на чтение и запись, на добавление). (В файле должно быть не менее 30 строк)....

Записать в конец файла таблицу с указанием трех наиболее часто встречающихся слов и количества их повторений
Само задание: Открыть текстовый файл в необходимом режиме (на чтение, на чтение и запись, на добавление). (В файле должно быть не менее 30...

Вывести таблицу с указанием трех наиболее часто встречающихся слов
Помогите пожалуйста! Написать программу, получающую строку текста и возвращающую таблицу с указанием трех наиболее часто встречающихся...

4
 Аватар для igorrr37
2869 / 2016 / 991
Регистрация: 21.12.2010
Сообщений: 3,724
Записей в блоге: 15
22.12.2018, 11: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
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
#include <iostream>
#include <string>
#include <regex>
#include <fstream>
#include <thread>
#include <algorithm>
#include <cctype>
#include <list>
#include <utility>
#include <map>
#include <unordered_map>
#include <clocale>
#include <functional>
 
 
// протестировано в MSVS2017
int main()
{
    setlocale(LC_CTYPE, "rus");
    std::fstream fs{"in.txt", std::ios::in | std::ios::out | std::ios::app};
    if (fs.is_open())
    {
        std::regex rgx{"[А-Яа-яЁё[:alpha:]\\d]+"};
        auto lmd{ [&rgx](std::multimap<int, std::string, std::greater<int>>& mmp, auto&& str)
        {
            std::unordered_map<std::string, int> ump;
            std::for_each(std::sregex_iterator{ str.begin(), str.end(), rgx }, {}, [&str, &ump](auto const& mr)
            {
                std::transform(str.begin() + mr.position(), str.begin() + mr.position() + mr.length(), str.begin() + mr.position(), [](char c) 
                {
                    return tolower(unsigned char (c));
                });
                ++ump[mr.str()];
            });
            for (auto const& pr : ump)
            {
                mmp.insert({ pr.second, pr.first });
            }
        } };
        std::list<std::multimap<int, std::string, std::greater<int>>> lm;
        std::list<std::thread> lt;
        std::string str;
        while (std::getline(fs, str))
        {
            lm.emplace_back();
            lt.emplace_back(lmd, std::ref(lm.back()), std::move(str));
        }
        for (auto& thr : lt)
        {
            thr.join();
        }
        for (auto const& mmp : lm)
        {
            int i = 0;
            for (auto const& pr : mmp)
            {
                std::cout << pr.second << ": " << pr.first << "    ";
                if (++i == 3)
                {
                    break;
                }
            }
            std::cout << std::endl;
        }
 
        fs.close();
    }
    else
    {
        std::cerr << "Unable to open file\n";
    }
}
1
0 / 0 / 0
Регистрация: 13.02.2017
Сообщений: 75
23.12.2018, 00:10  [ТС]
спасибо, но как записать в конец этого же файла таблицу с ответом?
0
 Аватар для igorrr37
2869 / 2016 / 991
Регистрация: 21.12.2010
Сообщений: 3,724
Записей в блоге: 15
23.12.2018, 02:08
Лучший ответ Сообщение было отмечено Nishen как решение

Решение

Lucky_fart, перенаправить вывод из cout в файл
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
#include <iostream>
#include <string>
#include <regex>
#include <iostream>
#include <string>
#include <regex>
#include <fstream>
#include <thread>
#include <algorithm>
#include <cctype>
#include <list>
#include <utility>
#include <map>
#include <unordered_map>
#include <clocale>
#include <functional>
 
 
// протестировано в MSVS2017
int main()
{
    setlocale(LC_CTYPE, "rus");
    std::fstream fs{ "in.txt", std::ios::in | std::ios::out | std::ios::app };
    if (fs.is_open())
    {
        std::regex rgx{ "[А-Яа-яЁё[:alpha:]\\d]+" };
        auto lmd{ [&rgx](std::multimap<int, std::string, std::greater<int>>& mmp, auto&& str)
        {
            std::unordered_map<std::string, int> ump;
            std::for_each(std::sregex_iterator{ str.begin(), str.end(), rgx }, {}, [&str, &ump](auto const& mr)
            {
                std::transform(str.begin() + mr.position(), str.begin() + mr.position() + mr.length(), str.begin() + mr.position(), [](char c)
                {
                    return tolower(unsigned char(c));
                });
                ++ump[mr.str()];
            });
            for (auto const& pr : ump)
            {
                mmp.insert({ pr.second, pr.first });
            }
        } };
        std::list<std::multimap<int, std::string, std::greater<int>>> lm;
        std::list<std::thread> lt;
        std::string str;
        while (std::getline(fs, str))
        {
            lm.emplace_back();
            lt.emplace_back(lmd, std::ref(lm.back()), std::move(str));
        }
        for (auto& thr : lt)
        {
            thr.join();
        }
        fs.clear();
        fs << "\n***\n";
        for (auto const& mmp : lm)
        {
            int i = 0;
            for (auto const& pr : mmp)
            {
                fs << pr.second << ": " << pr.first << "    ";
                if (++i == 3)
                {
                    break;
                }
            }
            fs << std::endl;
        }
 
        fs.close();
    }
    else
    {
        std::cerr << "Unable to open file\n";
    }
}
1
0 / 0 / 0
Регистрация: 13.02.2017
Сообщений: 75
25.12.2018, 01:38  [ТС]
спасибо)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.12.2018, 01:38
Помогаю со студенческими работами здесь

Перевод с C# на С++ (в заданном тексте найти 20 наиболее часто встречающихся слов с указанием количества использования каждого из них)
Помогите пожалуйста перевести с C# на С++.... Я не очень хорошо сейчас знаю библиотеку STL... Задание такое: В заданном тексте найти 20...

Получить 10 наиболее часто встречающихся слов из файла
Дан символьный файл f, содержащий произвольный текст длиной более 50 слов. Слова в тексте разделены пробелами и знаками препинания....

Получить 100 наиболее часто встречающихся слов файла и частоту их появления
Даны символьный файл f, содержащий произвольный текст длиной более 5000 слов. Слова в тексте разделены пробелами и знаками препинания....

20 наиболее часто встречающихся слов
дан файл. выписать 20 наиболее часто встречающихся слов в алфавитном порядке. (структуры использовать нельзя). помогите пожалуйста. заранее...

Поиск наиболее часто встречающихся слов
Помогите пожалуйста, нужно определить десятку наиболее часто встречающихся слов в 5 столбце Strigngrid


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru