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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> std::set find, insert - работа, std::set find, insert - работа 
:(
    Опции темы
livo
Дата 5.7.2011, 12:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Всем привет! Есть один вопрос по множеству. Нужно провести создание множества уникальних ключей и соответствующих им объектов. Но как подобрать уникальний ключ? В общем, у меня вот так это сделано:
Код

unsigned __fastcall TS::Create(TSu **pptr)
{
 //создаем объект для вставки в множество
 TSetEl se;
 se.id=1;
 se.ptr_su=new TSu;//связанный объект
 se.ptr_su->OnChange=on_change_su;
 while(sus.find(se)!=sus.end())se.id++;//подбираем уникальный ключ
 TSus::iterator i=sus.insert(se).first;//вставляем
 //возврат данных
 if(pptr)*pptr=i->ptr_su;
 changed=1;
 return se.id;
}

Но мне хотелось бы иначе оформить вставку. Ну например:
Код

//...
while(!sus.insert(se).second)se.id++;
//...

А как получить указатель на вставленный объект? Может есть какой-то тип итераторов, чтобы сохранить возвращенное значение функцией insert?
PM MAIL   Вверх
boostcoder
Дата 5.7.2011, 12:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


pattern`щик
****


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

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



livo, не хорошо постить в чужую тему. при том, теме уже около двух лет ;)

Добавлено через 1 минуту и 1 секунду
Цитата(livo @  5.7.2011,  12:34 Найти цитируемый пост)
создание множества уникальних ключей и соответствующих им объектов

std::map ?
PM WWW   Вверх
livo
Дата 5.7.2011, 13:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Цитата(boostcoder @  5.7.2011,  12:39 Найти цитируемый пост)
не хорошо постить в чужую тему

Учту.
Цитата(boostcoder @  5.7.2011,  12:39 Найти цитируемый пост)
std::map

Похоже здесь есть сразу то, что мне надо. Отличный вариант!
Ну а по множеству... Есть ли все-таки подходящий тип итераторов для сохранения результата функции insert множества?

PM MAIL   Вверх
boostcoder
Дата 5.7.2011, 13:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


pattern`щик
****


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

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



Цитата(livo @  5.7.2011,  13:21 Найти цитируемый пост)
Есть ли все-таки подходящий тип итераторов для сохранения результата функции insert множества?

ну так insert и возвращает тебе пару, в которой есть и итератор указывающий на вставленный элемент: http://cplusplus.com/reference/stl/set/insert/
PM WWW   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
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.1010 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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