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

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

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

Посчитать все элементы и наиболее часто встречающиеся - удалить - C++

29.05.2013, 14:43. Просмотров 478. Ответов 1
Метки нет (Все метки)

Помогите пожалуйста!
Используя класс list (либо map) из стандартной библиотеки шаблонов Stl посчитать из файла in.txt все слова в список и удалить из этого списка все вхождения наиболее часто встречающегося слова и вывести все оставшиеся слова на экран.

Добавлено через 15 минут
up!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.05.2013, 14:43     Посчитать все элементы и наиболее часто встречающиеся - удалить
Посмотрите здесь:

Наиболее часто встречающиеся слова - C++
Здравствуйте! Помогите, пожалуйста написать код, который из текстового файла со словами найдет 10 наиболее часто встречающихся слов и...

Найти и вывести на консоль символы, наиболее часто встречающиеся в заданной строке - C++
В тексте найти и напечатать символы, встречающиеся наиболее часто. Помогите !

Массивы. Найти частоту появления каждого из m элементов, наиболее часто встречающиеся (m << n) в процентах - C++
помогите пожалуйста с заданием на DEV C++ В целочисленном массиве K (n) многие элементы, которые повторяются. Найти частоту появления...

Удалить из массива все элементы, встречающиеся более 2 раз - C++
массив дан целочисленный одномерный массив.удалить из массива все элементы ,встречающиеся более 2 раз функция даны действительные...

Удалить из массива все элементы, встречающиеся ровно n раз - C++
1. Дан целочисленный массив ,состоящий из n элементов. Удалить из массива все элементы ,встречающиеся ровно n раз. 2. Дана целочисленная...

Удалить из массива все элементы, встречающиеся три раза - C++
Подскажите пожалуйста в чем ошибка последнего цикла. #include &lt;cstdlib&gt; #include &lt;iostream&gt; #include &lt;math.h&gt; /* Дан...

Удалить из массива все элементы, встречающиеся ровно два раза - C++
помогите, пожалуйста, как написать код в с++? Дан целочисленный массив размера N. Удалить из массива все элементы, встречающиеся ровно...

Удалить из массива все элементы встречающиеся более двух раз - C++
Дано целочисленный массив размера N. Удалить из массива все элементы, встречаются более двух раз , и вывести размер полученного массива и...

Посчитать в слове наиболее часто встречающийся символ и его процентное содержание - C++
Подскажите пожалуйста, как посчитать в слове наиболее часто встречающийся символ и его процентное содержание.. И все это вывести на экран!!...

Как вывести наиболее часто встречаемые элементы в массиве? - C++
Задание. Вывод наиболее часто встречаемых элементов в массиве Написать функцию, которая в массиве целых чисел a выводит информацию о ...

Удалить из массива все числа, у которых все цифры, встречающиеся в их записи, одинаковы - C++
Дан массив целых положительных чисел a1, a2, …аN. Удалить из него все числа, у которых все цифры, встречающиеся в их записи, одинаковы. ...

Удалить элементы массива встречающиеся ровно два раза - C++
дан массив, состоящий из 12 двоичных чисел. Удалить элементы, которые встречаются два раза


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
DiffEreD
1429 / 766 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
29.05.2013, 16:21     Посчитать все элементы и наиболее часто встречающиеся - удалить #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
#include <iostream>
#include <string>
#include <fstream>
#include <list>
#include <map>
#include <algorithm>
#include <iterator>
 
int main ()
{
    std::ifstream ifs("D:/file.txt");
    if (ifs.is_open())
    {
        std::list<std::string> words{std::istream_iterator<std::string>(ifs), std::istream_iterator<std::string>()};
        if (words.empty()) return 0;
        
        std::map<std::string, int> m;
        std::for_each(words.begin(), words.end(), [&m](const std::string& s) {++m[s];} );
        std::string be_delete = std::max_element(m.begin(), m.end(),
                [](const std::pair<std::string, int>& p1, const std::pair<std::string, int>& p2)
                {
                    return p1.second < p2.second; 
                })->first;
        words.remove_if([=](const std::string& s){return s == be_delete;});
        std::cout<<"Result:\n";
        std::copy(words.begin(), words.end(), std::ostream_iterator<std::string>(std::cout, " "));
    }
    else
        std::cout<<"Error...\n";
 
    return 0;
}
Ответ Создать тему
Опции темы

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