Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Массив для задания биекции 
:(
    Опции темы
XProgammer
Дата 24.9.2012, 17:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 13
Регистрация: 27.10.2011

Репутация: нет
Всего: нет



Привет))
Можно ли в C++ (или STL) для структуры
Код

struct

    char *string;
    int position;
    char *code;
    int number;
}

задать массив A такого типа
Код

{
{"string1",      1, "xxx" , 1000},
{"string2",      2, "yyy" , 2000}
{"somestring", 3, "aaa", 3000}
}


и потом обращаться по индексу любого из полей, например 

Код

assert( A[3000].string() == "somestring" ) 


или

Код

assert( A["string2"].code() == "yyy" ). 


Т.е. мне нужно поставить взаимно-однозначное соответствие 
между разными объектами, и потом иметь возможность используя в качестве индекса любое поле, узнать остальные поставленные ему в соответствие значения, а не тупо перебором и сравнением 


PM MAIL   Вверх
math64
Дата 24.9.2012, 17:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 8
Всего: 72



Задать такой массив можно.
Но индексироваться строкой нельзя.
При индексировании целым числом получишь структру в массиве с соответствующим номером, а не с полем нужного значения.
Сравнивать строки с помощью == можно если только они заданы строковыми константами в одном файле.
Обычно для этого нужно strcmp()
PM   Вверх
baldina
Дата 24.9.2012, 17:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3433
Регистрация: 5.12.2007
Где: Москва

Репутация: 32
Всего: 101



Boost Multi-index

Добавлено @ 17:52
Цитата(math64 @  24.9.2012,  17:47 Найти цитируемый пост)
Сравнивать строки с помощью == можно если только они заданы строковыми константами в одном файле.
Обычно для этого нужно strcmp() 

В С++ (STL) для этого имеется std::string.

Добавлено через 3 минуты и 56 секунд
В STL есть контейнер std::map - реализация словаря, позволяет хранить данные типа ключ-значение
вышеупомянутый boost::multi_index - обобщение словаря до мульти-словаря, как раз как Вы желаете

Это сообщение отредактировал(а) baldina - 24.9.2012, 17:52
PM MAIL   Вверх
KaZepKa
Дата 24.9.2012, 18:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 37
Регистрация: 29.10.2011

Репутация: нет
Всего: нет



а можно и свой класс описать и сделать как хочется
PM MAIL   Вверх
XProgammer
Дата 24.9.2012, 23:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 13
Регистрация: 27.10.2011

Репутация: нет
Всего: нет



Цитата



В STL есть контейнер std::map - реализация словаря, позволяет хранить данные типа ключ-значение
вышеупомянутый boost::multi_index - обобщение словаря до мульти-словаря, как раз как Вы желаете



спасибо большое, посмотрю))

Цитата


а можно и свой класс описать и сделать как хочется


свой класс непонятно как))
PM MAIL   Вверх
baldina
Дата 25.9.2012, 10:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3433
Регистрация: 5.12.2007
Где: Москва

Репутация: 32
Всего: 101



Цитата(XProgammer @ 24.9.2012,  23:00)
Цитата

а можно и свой класс описать и сделать как хочется

свой класс непонятно как))

свой запаришься писать. для каждого ключа (поля в структуре) нужно иметь свой индекс - отсортированный массив указателей (или двоичное дерево поиска) или хеш-таблицу. по индексу можно быстро найти нужный.
для простоты в качестве индекса можно использовать std::map или std::hash_map, но останется проблема синхронизации, которую придется решать самостоятельно.
так что готовое имхо наиболее быстрый путь
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0821 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.