Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
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