Какой шаблон/алгоритм наиболее эффективен для сравнения двух списков и поиска разницы между этими двумя списками?C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Какой шаблон/алгоритм наиболее эффективен для сравнения двух списков и поиска разницы между этими двумя списками?

Сообщение Anonymous »

У нас есть два списка учащихся и их оценки: Я хочу сравнить эти два списка

[*]найдите разницу между новым списком и старым списком,
[*]затем найдите наименее навязчивый способ вставки или обновления в новый список любых изменений.
< /ul>
Какой алгоритм лучше всего подходит для этого? Хотите сосредоточиться на минимальном количестве изменений в новом списке и производительности.
Пример кода:

Код: Выделить всё

List existingList = new List();
List newList = new List();

public TopLists()
{
InitTwoLists();
}

private void InitTwoLists()
{
existingList.Add(new ListItem { Name = "Shane", Score = 100 });
existingList.Add(new ListItem { Name = "Mark", Score = 95 });
existingList.Add(new ListItem { Name = "Shane", Score = 94 });
existingList.Add(new ListItem { Name = "Steve", Score = 90 });
existingList.Add(new ListItem { Name = "Brian", Score = 85 });
existingList.Add(new ListItem { Name = "Craig", Score = 85 });
existingList.Add(new ListItem { Name = "John", Score = 82 });
existingList.Add(new ListItem { Name = "Steve", Score = 81 });
existingList.Add(new ListItem { Name = "Philip", Score = 79 });
existingList.Add(new ListItem { Name = "Peter", Score = 70 });

newList.Add(new ListItem { Name = "Shane", Score = 100 });
// This is change
newList.Add(new ListItem { Name = "Steve", Score = 96 });
newList.Add(new ListItem { Name = "Mark", Score = 95 });
newList.Add(new ListItem { Name = "Shane", Score = 94 });
newList.Add(new ListItem { Name = "Brian", Score = 85 });
newList.Add(new ListItem { Name = "Craig", Score = 85 });
newList.Add(new ListItem { Name = "John", Score = 82 });
newList.Add(new ListItem { Name = "Steve", Score = 81 });
newList.Add(new ListItem { Name = "Philip", Score = 79 });
newList.Add(new ListItem { Name = "Peter", Score = 70 });
}
}
Как реализовать CompareLists()

Код: Выделить всё

public void CompareLists()
{
// How would I find the deltas and update the
// new list with any changes from old?
}
}

public class ListItem
{
public string Name { get; set; }
public int Score { get; set; }
}
** РЕДАКТИРОВАТЬ: Желаемый результат ***
Желаемый результат — фактически изменить newList с помощью дельт.
Например. в этом сценарии:

Код: Выделить всё

newList.Add(new ListItem { Name = "Shane", Score = 100 });
newList.Add(new ListItem { Name = "Steve", Score = 96 });  // This is change
newList.Add(new ListItem { Name = "Mark", Score = 95 });
newList.Add(new ListItem { Name = "Shane", Score = 94 });
newList.Add(new ListItem { Name = "Brian", Score = 85 });
newList.Add(new ListItem { Name = "Craig", Score = 85 });
newList.Add(new ListItem { Name = "John", Score = 82 });
newList.Add(new ListItem { Name = "Steve", Score = 81 });
newList.Add(new ListItem { Name = "Roger", Score = 80 });  // Roger is a new entry
newList.Add(new ListItem { Name = "Phillip", Score = 79 });  // Philip moved down one
// Питер исключается из этого списка со своим результатом 70, поскольку мне нужны только 10 лучших.
Итак, изменения будут такими:< /p>
Обновить запись 2 для «Стив», счет изменился.
Вставить новую запись «Роджер» на позицию 9.
Удалить запись «Питер» из топ-10. .

Подробнее здесь: https://stackoverflow.com/questions/368 ... find-the-d
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C#»