Instance Method

firstIndex(where:)

Returns the first index in which an element of the collection satisfies the given predicate.

Declaration

func firstIndex(where predicate: (Character) throws -> Bool) rethrows -> String.Index?

Parameters

predicate

A closure that takes an element as its argument and returns a Boolean value that indicates whether the passed element represents a match.

Return Value

The index of the first element for which predicate returns true. If no elements in the collection satisfy the given predicate, returns nil.

Discussion

You can use the predicate to find an element of a type that doesn’t conform to the Equatable protocol or to find an element that matches particular criteria. Here’s an example that finds a student name that begins with the letter “A”:

let students = ["Kofi", "Abena", "Peter", "Kweku", "Akosua"]
if let i = students.firstIndex(where: { $0.hasPrefix("A") }) {
    print("\(students[i]) starts with 'A'!")
}
// Prints "Abena starts with 'A'!"

Complexity: O(n), where n is the length of the collection.

See Also

Finding Characters

func contains(Character) -> Bool

Returns a Boolean value indicating whether the sequence contains the given element.

func allSatisfy((Character) -> Bool) -> Bool

Returns a Boolean value indicating whether every element of a sequence satisfies a given predicate.

func contains(where: (Character) -> Bool) -> Bool

Returns a Boolean value indicating whether the sequence contains an element that satisfies the given predicate.

func first(where: (Character) -> Bool) -> Character?

Returns the first element of the sequence that satisfies the given predicate.

func firstIndex(of: Character) -> String.Index?

Returns the first index where the specified value appears in the collection.

func last(where: (Character) -> Bool) -> Character?

Returns the last element of the sequence that satisfies the given predicate.

func lastIndex(of: Character) -> String.Index?

Returns the last index where the specified value appears in the collection.

func lastIndex(where: (Character) -> Bool) -> String.Index?

Returns the index of the last element in the collection that matches the given predicate.

func max() -> Character?

Returns the maximum element in the sequence.

func max(by: (Character, Character) -> Bool) -> Character?

Returns the maximum element in the sequence, using the given predicate as the comparison between elements.

func min() -> Character?

Returns the minimum element in the sequence.

func min(by: (Character, Character) -> Bool) -> Character?

Returns the minimum element in the sequence, using the given predicate as the comparison between elements.