OK I did this experiment and here is the result:
This is the elapsed ticks for a list and linked list with 1000,000 items:
LinkedList 500 insert/remove operations: 10171
List 500 insert/remove operations: 968465
Linked list is 100 times faster when compared for 1000,000 items.
Here is the code:
static void Main(string[] args)
{
const int N = 1000*1000;
Random r = new Random();
LinkedList linkedList = new LinkedList();
List list = new List();
List> linkedListNodes = new List>();
for (int i = 0; i < N; i++)
{
list.Add(r.Next());
LinkedListNode linkedListNode = linkedList.AddFirst(r.Next());
if(r.Next() % 997 == 0)
linkedListNodes.Add(linkedListNode);
}
Stopwatch stopwatch = new Stopwatch();
stopwatch.Start();
for (int i = 0; i < 500; i++)
{
linkedList.AddBefore(linkedListNodes[i], r.Next());
linkedList.Remove(linkedListNodes[i]);
}
stopwatch.Stop();
Console.WriteLine("LinkedList 500 insert/remove operations: {0}", stopwatch.ElapsedTicks);
stopwatch.Reset();
stopwatch.Start();
for (int i = 0; i < 500; i++)
{
list.Insert(r.Next(0,list.Count), r.Next());
list.RemoveAt(r.Next(0, list.Count));
}
stopwatch.Stop();
Console.WriteLine("List 500 insert/remove operations: {0}", stopwatch.ElapsedTicks);
Console.Read();
}
}