hi!
is there in C# some already defined generic container which can be used as Stack and as Queue at the same time? I just want to be able to append elements either to the end, or to the front of the queue
thanks
hi!
is there in C# some already defined generic container which can be used as Stack and as Queue at the same time? I just want to be able to append elements either to the end, or to the front of the queue
thanks
What you want is a linked list - there's one in the BCL - that has AddFirst and AddLast methods
Check the LinkedList class.
LinkedList<int> list = new LinkedList<int>();
list.AddFirst(1);
list.AddLast(2);
list.AddFirst(0);
Here's my implementation of an immutable deque:
Notice that this is an immutable double-ended-queue. Normally you probably think of a queue as something you mutate:
queue.Enqueue(10);
An immutable queue always stays the same; when you add a new element, it gives you back an entirely new queue, so you use it as:
queue = queue.Enqueue(10);
if you no longer care about the old value.
Good old List<T>
will do it.
Add()
to enqueue, Insert(0,T)
to push, Remove(0)
to pop/dequeue.