List.findIndex<'T> (Función de F#)
Devuelve el índice del primer elemento de la lista que cumple el predicado especificado.Se produce la excepción KeyNotFoundException si no existe ese elemento.
Espacio de nombres/Ruta de acceso del módulo: Microsoft.FSharp.Collections.List
Ensamblado: FSharp.Core (en FSharp.Core.dll)
// Signature:
List.findIndex : ('T -> bool) -> 'T list -> int
// Usage:
List.findIndex predicate list
Parámetros
predicate
Tipo: 'T ->boolFunción que se va a usar para comprobar los elementos de entrada.
list
Tipo: 'TlistaLista de entrada.
Excepciones
Excepción |
Condition |
---|---|
Se produce si el predicado se evalúa como false para todos los elementos de la lista. |
Valor devuelto
Índice del primer elemento que satisface el predicado.
Comentarios
Esta función se denomina FindIndex en los ensamblados compilados.Si obtiene acceso a la función desde un lenguaje .NET distinto de F# o mediante reflexión, use este nombre.
Ejemplo
En el código siguiente se muestra cómo usar List.findIndex y compara su comportamiento con el de List.find.
let list1 = [ 2 .. 100 ]
let delta = 1.0e-10
let isPerfectSquare (x:int) =
let y = sqrt (float x)
abs(y - round y) < delta
let isPerfectCube (x:int) =
let y = System.Math.Pow(float x, 1.0/3.0)
abs(y - round y) < delta
let element = List.find (fun elem -> isPerfectSquare elem && isPerfectCube elem) list1
let index = List.findIndex (fun elem -> isPerfectSquare elem && isPerfectCube elem) list1
printfn "The first element that is both a square and a cube is %d and its index is %d." element index
Output
Plataformas
Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Información de versiones
Versiones de la biblioteca básica de F#
Se admite en: 2.0, 4.0, portables