Najlepszy algorytm usuwania zduplikowanych wartości z listy

Jaki jest najlepszy algorytm usuwania zduplikowanych wartości z listy? Próbowałem tego:

for (int i = 0; i < AuthorCounter-1; i++)
{
    for (int j = 0; j < AuthorCounter-1; j++)
    {
        if (i != j)
        {
            if (AuthorGroupNode.Nodes[i].Text == AuthorGroupNode.Nodes[j].Text)
            {
                AuthorGroupNode.Nodes[j].Remove();
                AuthorCounter--;
            }

        }
    }
}

Tutaj,AuthorGroupNodes to lista na węzłach. Robiło to dobrze do pewnego stopnia, ale nie do końca. Każdy ma lepsze rozwiązanie?

questionAnswers(4)

yourAnswerToTheQuestion