I have two List which I am accessing by index (e.g. Name[10], Date[10]). They’re closely tied, so Name[10] is related to Date[10] and vice versa.
This design has worked well but now I need to sort them. I can sort them both individually but obviously that would remove the relationship between the two lists and make them worthless.
I thought about using a Dictionary<string, DateTime> instead but it seems I can only access that by Key (which is also unworkable). Essentially I need three things, two values and one index which I can iterate through numerically (not foreach).
Can anyone help? It seems I either need to change data-structure or work out how to sort two distinct List<T> together…
public class Results
{
public List<string> Name { get; set; }
public List<DateTime> Date{ get; set; }
}
for (int x = 0; x < results; x++)
{ z.N = results.Name[X]; z.D = results.Date[x]; }
It sounds like you’re fighting against doing the obvious solution which involves a little bit of upfront work: creating a type to encapsulate the name/date pair.
That’s absolutely what you should do. Then you can have one list, sort it by name or by date or whatever you want, and you never need to worry about the two lists getting out of sync etc.
If your
Resultsclass doesn’t do anything apart from contain those two lists, you can actually end up with the same number of types – you can ditchResultsentirely, in favour ofList<Result>whereResulthas a name and a date.