Skip to content

Latest commit

 

History

History

Linear-Search

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Linear Search

Goal: Find a particular value in an array.

We have an array of generic objects. With linear search, we iterate over all the objects in the array and compare each one to the object we're looking for. If the two objects are equal, we stop and return the current array index. If not, we continue to look for the next object as long as we have objects in the array.

An example

Let's say we have an array of numbers [5, 2, 4, 7] and we want to check if the array contains the number 2.

We start by comparing the first number in the array, 5, to the number we're looking for, 2. They are obviously not the same, and so we continue to the next array element.

We compare the number 2 from the array to our number 2 and notice they are equal. Now we can stop our iteration and return 1, which is the index of the number 2 in the array.

The code

Here is a simple implementation of linear search in Go:

func linearSearch(nums []int, target int) int {
    for index := range nums {
        if nums[index] == target {
            return index
        }
    }
    
    return -1
}

Put this code in the Go Playground and test it like so:

array := []int{5, 2, 4, 7}
linearSearch(array, 2) 	// This will return 1

Performance

Linear search runs at O(n). It compares the object we are looking for with each object in the array and so the time it takes is proportional to the array length. In the worst case, we need to look at all the elements in the array.

The best-case performance is O(1) but this case is rare because the object we're looking for has to be positioned at the start of the array to be immediately found. You might get lucky, but most of the time you won't. On average, linear search needs to look at half the objects in the array.

See also

Linear search on Wikipedia

Reference material written for Swift Algorithm Club by Patrick Balestra
Adapted for Go Algorithm Club by Jon Lim