Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для gromo
383 / 281 / 31
Регистрация: 04.09.2009
Сообщений: 1,225

Выбор структуры данных

18.12.2014, 22:12. Показов 527. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужна ассоциативная структура, которая будет не строго упорядоченной (элементы должны лежать в порядке их вставки). + желательно, чтобы ключи не могли повторяться.

Решил пока таким образом (правда ключи могут повторяться):
C++
1
2
3
std::multimap< std::string, int, 
                                std::function<bool(std::string,std::string)>> 
                  words([](std::string,std::string){return false;});
Можно ли сделать это как-нибудь элегантнее, с неповторяющимися ключами, с использованием STL ?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.12.2014, 22:12
Ответы с готовыми решениями:

Выбор оптимальной структуры данных
Здравствуйте! Задача состоит в следующем. Есть большой файл (~68 mb) с текстом. Нужно посчитать сколько раз встречается каждое слово...

Выбор структуры данных для вставки, удаления и поиска минимума за log(n)
Добрый день!Подскажите какую нибудь структуру, чтобы были операции: вставка,удаление,и поиск минимума за log(n). Если найдутся исходники...

Понятие структуры данных. Элементарные структуры данных. Простые структуры данных
Понятие структуры данных. Элементарные структуры данных. Простые структуры данных: методы реализации, особенности в различных языках...

4
3176 / 1935 / 312
Регистрация: 27.08.2010
Сообщений: 5,131
Записей в блоге: 1
18.12.2014, 22:19
Цитата Сообщение от gromo Посмотреть сообщение
элементы должны лежать в порядке их вставки + желательно, чтобы ключи не могли повторяться
Классическая (если необходимо, in memory) DB с уникальным индексом.
1
 Аватар для gromo
383 / 281 / 31
Регистрация: 04.09.2009
Сообщений: 1,225
18.12.2014, 22:22  [ТС]
gazlan, а можно подробнее куда копать, чтобы сделать db in memory? А с использованием STL никак нельзя?
0
3176 / 1935 / 312
Регистрация: 27.08.2010
Сообщений: 5,131
Записей в блоге: 1
18.12.2014, 22:38
Цитата Сообщение от gromo Посмотреть сообщение
с использованием STL
Вам шашечки или ехать?

In-memory DB сколько угодно готовых. Хочется дрянную собственную - делаете массив и индекс к нему.
1
 Аватар для gromo
383 / 281 / 31
Регистрация: 04.09.2009
Сообщений: 1,225
19.12.2014, 15:56  [ТС]
Цитата Сообщение от gazlan Посмотреть сообщение
Вам шашечки или ехать?
У меня объёмы данных не очень большие (до 200 пар ключ/значение), поэтому решил таким велосипедом

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
inline template <class Key, class T, class Compare, class Allocator>
Key getKeyByValue(const std::multimap<Key, T, Compare, Allocator>& mm, const T& value)
{
    return std::find_if(mm.cbegin(), mm.cend(), 
              [&] (const typename std::allocator_traits<Allocator>::value_type& keyValuePair){
       return keyValuePair.second == value; })->first;
}
 
int main()
{
    std::multimap< std::string, int,
                                    std::function<bool(std::string,std::string)>>
                      words([](std::string,std::string){return false;});
 
    words.emplace("str1", 1);
    words.emplace("str2", 2);
    words.emplace("str3", 3);
    words.emplace("str4", 4);
 
    std::cout << getKeyByValue(words, 3) << std::endl; // OK: str3
}
Но за ссылочки спасибо, обязательно почитаю.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.12.2014, 15:56
Помогаю со студенческими работами здесь

Выбор структуры данных
Здравствуйте. При выборе структуры данных возникли проблемы. Нужно хранить в типизированном файле тестовые задания. Сейчас структура...

Выбор структуры сохранения данных
Здравствуйте! В целях обучения Java и смежных технологий решил написать клиент-серверное приложение (в данном топике затрагивается только...

Морской бой. Выбор структуры данных
при создании морского боя можно ли использовать структуру вместо класса и как вопще проще создавать его как примерно алгортм .

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

Динамические структуры данных. Организация данных в списковые структуры
Написать программу, формирующую два списка, заполняя их числами из файлов. Объединить оба списка в один, вставляя элементы поочередно то из...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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