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

Записать в мапу значения

22.01.2018, 13:13. Показов 767. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть текст, мне нужно пощитать сколько раз символ встречается в тексте. Я расбиваю на потоки, потоки записываю в мапы. и Теперь мне нужно все маленькие мапы записать в главную мапу. И поэтому мне нужно уже учитывать а был ли уже этот символ записан. И суму символов еще учитывать. Но я не знаю как это реализовать (
Как я думаю делать: Мне нужно вставить(insert) в мапу если первый раз или добавить к тому что уже было вставлено если такие ключ-значение уже вставлены. Но повторюсь у меня не выходит:
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
int main() 
{
    auto text = ReadDataFromFile("D:\\text.txt");
 
    const auto textIntervals = GenerateIntervals(text);
    const auto usedThreadCount = textIntervals.size();
 
    std::vector<std::unordered_map<char, size_t>> histograms(usedThreadCount);
    std::vector<std::thread> threads(usedThreadCount);
 
    for (std::size_t i = 0; i < usedThreadCount; ++i)
        threads[i] = std::thread(BuildHistogram, std::cref(textIntervals[i]), text, std::ref(histograms[i]));
 
    for (std::size_t i = 0; i < usedThreadCount; ++i)
        threads[i].join();
 
    std::unordered_map<char, size_t> histogram;
    for (const auto& hist : histograms) 
    {
        for (const auto& pair : hist)
                    histogram.insert(pair);
    }
 
    return 0;
}
Зараз я просто все записываю в главную мапу

C++
1
2
3
4
5
6
7
8
9
10
std::vector<std::unordered_map<char, size_t>> histograms(usedThreadCount); // создаю вектор с мапами
    std::vector<std::thread> threads(usedThreadCount); // 
 
    
    std::unordered_map<char, size_t> histogram; // создаю  главную мапу , куда мне и нужно писать
    for (const auto& hist : histograms) 
    {
        for (const auto& pair : hist)
                    histogram.insert(pair); //  от тут  нужно  деалть ифы  но как я  хз.
    }
Поэтому нужна ваша помощь с нормальной записю в мапу.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.01.2018, 13:13
Ответы с готовыми решениями:

Записать в массив указанные значения
Доброй ночи, нужно решить 2 задачки по с++, заранее спасибо) 1. Записать в массив А(15) первые 5 элементов “0”, затем 5 элементов “2” и...

записать значения в одн.массив
вычисляю значения х и х1 три раза. как их записать в один одномерный массив? ...

Записать в одномерный массив значения функции
Записать в массив значения функции f(x)=x^2+b для х=1,2,..,20 и вывести его на экран

4
277 / 226 / 93
Регистрация: 27.06.2016
Сообщений: 639
22.01.2018, 13:41
olena_nov, ваш русский сложноват для понимания. У map и unordered_map есть перегруженная операция [], возвращающая ссылку на значение по ключу. Если ключа нет, вставляется значение по-умолчанию, которое для целочисленных типов = 0 (для экземпляров классов вызывается конструктор по умолчанию).
Так что:
C++
1
2
3
4
5
for (const auto& hist : histograms) 
    {
        for (const auto& pair : hist)
                    histogram[pair.first] += pair.second;
    }
1
1 / 1 / 0
Регистрация: 11.12.2017
Сообщений: 44
22.01.2018, 15:06  [ТС]
alex white, спасибо
и еще такая у меня проблема, Креш(assert), я продебажилась и на этой строчке креш
Code
1
const auto usedThreadCount = textIntervals.size();
но я не понимаю по чему там креш. Может вы подскажите?
весь код меина
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
int main() 
{
    auto text = ReadDataFromFile("D:\\text.txt");
 
    const auto textIntervals = GenerateIntervals(text);
    const auto usedThreadCount = textIntervals.size();
 
    std::vector<std::unordered_map<char, size_t>> histograms(usedThreadCount);
    std::vector<std::thread> threads(usedThreadCount);
 
    for (std::size_t i = 0; i < usedThreadCount; ++i)
        threads[i] = std::thread(BuildHistogram, std::cref(textIntervals[i]), text, std::ref(histograms[i]));
 
    for (std::size_t i = 0; i < usedThreadCount; ++i)
        threads[i].join();
 
    std::unordered_map<char, size_t> histogram;
    for (const auto& hist : histograms)
    {
        for (const auto& pair : hist) 
        {
            histogram[pair.first] += pair.second;
            std::cout << pair.first << " " << pair.second << std::endl;
        }   
    }
 
    /*for (int ch = 0; ch < 256; ++ch) 
    {
        if (text[ch]) 
        {
            std::cout << "Character '" << char(ch) << "' occurs " << text[ch] << " times\n";
        }
    }*/
    return 0;
}
0
277 / 226 / 93
Регистрация: 27.06.2016
Сообщений: 639
22.01.2018, 17:19
olena_nov, GenerateIntervals покажите.
0
1 / 1 / 0
Регистрация: 11.12.2017
Сообщений: 44
22.01.2018, 18:30  [ТС]
alex white,
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
std::vector<std::pair<std::size_t, std::size_t>> GenerateIntervals(const std::vector<char>& text)
{
    std::size_t maxThreadCount = std::thread::hardware_concurrency();
    const std::size_t minLength = text.size() / maxThreadCount;
    const std::size_t modulo = text.size() % maxThreadCount;
 
    std::vector<std::size_t> intervalLengthPerThread;
    intervalLengthPerThread.reserve(maxThreadCount);
 
    for (std::size_t i = 0; i < modulo; ++i)
        intervalLengthPerThread.emplace_back(minLength + 1);
 
    if (minLength > 0)
    {
        for (std::size_t i = modulo; i < maxThreadCount; ++i)
            intervalLengthPerThread.emplace_back(minLength);
    }
 
    std::vector<std::pair<std::size_t, std::size_t>> intervals;
    intervals.reserve(intervalLengthPerThread.size());
 
    intervals.emplace_back(0, 0 + intervalLengthPerThread[0] - 1);
    for (std::size_t i = 1; i < intervalLengthPerThread.size(); ++i)
        intervals.emplace_back(intervals[i - 1].second + 1, intervals[i - 1].second + intervalLengthPerThread[i]);
 
    return intervals;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.01.2018, 18:30
Помогаю со студенческими работами здесь

Записать в массив Y неотрицательные значения функции
Записать в массив Y неотрицательные значения функции sin(n*x)-n*cos(n*x) для X от 0 до 2 с шагом 0.1 (при заданном значении ), а в массив Х...

Записать значения функции на промежутке в файл
Здравствуйте. я выполнял задание: В соответствии с Вашим вариантом напишите и отладьте программу, которая записывает в двоичный файл...

Записать числовые значения из файла в массив
Есть такой код Извините за беспокойство, хотел спросить, как производится запись из файла в массив на языке С++? Есть такой...

Записать в массив неотрицательные значения заданной функции
Записать в массив Y неотрицательные значения функции sin(n*x)-n*cos(n*x) для X от 0 до 2 с шагом 0.1 (при заданном значении ), а в массив Х...

Как записать в переменную значения других переменных?
Как мне сделать так, чтобы в 3 строке были их значения? String login = Edit1-&gt;Text; String pass = Edit2-&gt;Text; AnsiString...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru