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.
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.
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
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.
Reference material written for Swift Algorithm Club by Patrick Balestra
Adapted for Go Algorithm Club by Jon Lim