ultimo - Obtiene la posición del elemento List<> en c#usando LINQ
obtener elemento de una lista c# (9)
Como solicitó específicamente una solución LINQ, y todo lo que obtuvo fueron soluciones que no son LINQ, aquí hay una solución LINQ:
List<int> values = new List<int> { 3, 1, 0, 5 };
int index =
values
.Select((n, i) => new { Value = n, Index = i })
.OrderBy(n=>n.Value)
.First()
.Index;
Sin embargo, eso no significa que LINQ sea la mejor solución para este problema ...
Editar:
Con un código un poco más complejo esto funciona un poco mejor:
int index =
values
.Select((n, i) => new { Value = n, Index = i })
.Aggregate((a,b) => a.Value < b.Value ? a : b)
.Index;
Para obtener el mejor rendimiento, usaría un bucle simple para ver los elementos, mientras realiza un seguimiento de los más bajos:
int index = 0, value = values[0];
for (int i = 1; i < values.Length; i++) {
if (values[i] < value) {
value = values[i];
index = i;
}
}
Tengo una lista con números, me gustaría encontrar la posición del mínimo (sin valor) usando LINQ
Ej .: {3,1,0,5} salida = 2
Estoy de acuerdo en que LINQ no es la mejor solución para este problema, pero aquí hay otra variación que es O (n). No ordena y solo cruza la lista una vez.
var list = new List<int> { 3, 1, 0, 5 };
int pos = Enumerable.Range(0, list.Count)
.Aggregate((a, b) => (list[a] < list[b]) ? a : b); // returns 2
La mejor forma de atrapar la posición es mediante FindIndex
Esta función está disponible solo para List <>
Ejemplo
int id = listMyObject.FindIndex(x => x.Id == 15);
Si tiene enumerador o matriz, use de esta manera
int id = myEnumerator.ToList().FindIndex(x => x.Id == 15);
o
int id = myArray.ToList().FindIndex(x => x.Id == 15);
No recomiendo necesariamente este código de estilo CPS, pero funciona y es O (n), a diferencia de las soluciones que usan OrderBy:
var minIndex = list.Aggregate(
new { i = 0, mini = -1, minv = int.MaxValue },
(min, x) => (min.minv > x)
? new { i = min.i + 1, mini = min.i, minv = x }
: new { i = min.i + 1, mini = min.mini, minv = min.minv })
.mini;
Cambie> a> = si quiere el último mínimo duplicado, no el primero.
Use .minv para obtener el valor mínimo o ninguno para obtener una 2-tupla con el índice y el valor mínimo.
No puedo esperar a que .NET obtenga tuplas en 4.0.
List<int> data = new List<int>();
data.AddRange(new[] { 3, 1, 0, 5 });
Console.WriteLine(data.IndexOf(data.Min()));
List<int>.Enumerator e = l.GetEnumerator();
int p = 0, min = int.MaxValue, pos = -1;
while (e.MoveNext())
{
if (e.Current < min)
{
min = e.Current;
pos = p;
}
++p;
}
int min = 0;
bool minIsSet = false;
var result = ints
.Select( (x, i) => new {x, i}
.OrderBy(z => z.x)
.Select(z =>
{
if (!minIsSet)
{
min = z.x;
minIsSet = true;
}
return z;
}
.TakeWhile(z => z.x == min)
.Select(z => z.i);
var data = new List<int> { 3, 1, 0, 5 };
var result = Enumerable.Range(0, data.Count).OrderBy(n => data[n]).First();
var list = new List<int> { 3, 1, 0, 5 };
int pos = list.IndexOf(list.Min()); // returns 2