Ja to napisałem:
public static class EnumerableExtensions
{
public static int IndexOf<T>(this IEnumerable<T> obj, T value)
{
return obj
.Select((a, i) => (a.Equals(value)) ? i : -1)
.Max();
}
public static int IndexOf<T>(this IEnumerable<T> obj, T value
, IEqualityComparer<T> comparer)
{
return obj
.Select((a, i) => (comparer.Equals(a, value)) ? i : -1)
.Max();
}
}
Ale nie wiem, czy już istnieje, prawda?
ToList()/FindIndex()
wykonuje trik najlepiej
Max
podejściem polega na tym, że a: szuka dalej, a b: zwraca ostatni indeks, gdy są duplikaty (ludzie zwykle oczekują pierwszego indeksu)