Ho scritto questo:
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();
}
}
Ma non so se esiste già, vero?
ToList()/FindIndex()
trucco funziona meglio
Max
approccio è che a: continua a cercare eb: restituisce l' ultimo indice quando ci sono duplicati (la gente di solito si aspetta il primo indice)