我有一个std :: deque,我想在指定的索引处插入一个元素(我知道std :: list会更好)。 deque :: insert()函数使用迭代器指定要插入的位置。给定一个索引,如何获得指向该位置的迭代器,以便我可以将该迭代器传递给insert()?
例如:
void insertThing ( deque<Thing> & things, Thing thing, size_t index )
{
deque<Thing>::iterator it = /* what do I do here? */
things.insert ( it, thing );
}
我确信这是一个非常基本的问题,我为此道歉。自从我使用STL已经有很长一段时间了,我在std :: deque的成员列表中看不到任何显然符合我想要的东西。感谢。
答案 0 :(得分:22)
void insertThing ( deque<Thing> & things, Thing thing, size_t index )
{
deque<Thing>::iterator it = things.begin() + index;
things.insert ( it, thing );
}
答案 1 :(得分:10)
deque支持随机访问,因此您应该能够说
things.insert( my_deque.begin() + index, thing);