Is there a data structure like a queue which also supports removal of elements at arbitrary points? Enqueueing and dequeueing occur most frequently, but mid-queue element removal must be similar in speed terms since there may be periods where that is the most common operation. Consistency of performance is more important than absolute speed. Time is more important than memory. Queue length is small, under 1,000 elements at absolute peak load.In case it’s not obvious I’ll state it explicitly: random insertion is not required.
Have tagged C++ since that is my implementation language, but I’m not using (and don’t want to use) any STL or Boost. Pure C or C++ only (I will convert C solutions to a C++ class.)
Edit: I think what I want is a kind of dictionary that also has a queue interface (or a queue that also has a dictionary interface) so that I can do things like this:
Container.enqueue(myObjPtr1);
MyObj *myObjPtr2 = Container.dequeue();
Container.remove(myObjPtr3);
I think that double-link list is exactly what you want (assuming you do not want a priority queue):
You can use
std::listcontainer, but (in your case) it is difficult to remove an elementfrom the middle of the list if you only have a pointer (or reference) to the element (wrapped in STL’s list element), but
you do not have an iterator. If using iterators (e.g. storing them) is not an option – then implementing a double linked list (even with element counter) should be pretty easy. If you implement your own list – you can directly operate on pointers to elements (each of them contains pointers to both of its neighbours). If you do not want to use Boost or STL this is probably the best option (and the simplest), and you have control of everything (you can even write your own block allocator for list elements to speed up things).