What is Searching ?
Searching is the process of finding some particular element in the list. If the element is present in the list, then the process is called successful and the process returns the location of that element, otherwise the search is called unsuccessful.
What is Linear Search ?
Linear search is the simplest search algorithm and often called sequential search. In this type of searching, we simply traverse the list completely and match each element of the list with the item whose location is to be found. If the match found then location of the item is returned otherwise the algorithm return NULL.
Linear Search Algorithm :
LINEAR_SEARCH(ARR, N, VAL)
- Step 1: [INITIALIZE] SET POS = -1
- Step 2: [INITIALIZE] SET I = 1
- Step 3: Repeat Step 4 while I<=N
- Step 4: IF ARR[I] = VAL
 SET POS = I
 PRINT POS
 Go to Step 6
 [END OF IF]
 SET I = I + 1
 [END OF LOOP]
- Step 5: IF POS = -1
 PRINT ” VALUE IS NOT PRESENTIN THE ARRAY ”
 [END OF IF]
- Step 6: EXIT

Complexity of Algorithm :
- Time Complexity : O(n)
- Space Complexity : O(1)
Code :
module Algos.Search
  ( linearSearch
  )
  where
import Prelude
import Data.List (List(..))
-- | Recursive linear search.
linearSearchRec :: forall a. Eq a => List a -> a -> Int -> Int
linearSearchRec Nil _ _ = -1
linearSearchRec (Cons x xs) val n 
  | x == val  = n
  | otherwise = linearSearchRec xs val (n + 1)
-- | linearSearch function uses linearSearchRec with initial index as 0.
linearSearch :: forall a. Eq a => List a -> a ->  Int
linearSearch xs val = linearSearchRec xs val 0