KEMBAR78
Data Search Algorithm | PDF | Array Data Structure | Data Management
0% found this document useful (0 votes)
135 views18 pages

Data Search Algorithm

The document summarizes two common search algorithms: linear search and binary search. Linear search sequentially checks each element of a list to find a target value. It has O(n) time complexity but is simple to implement. Binary search works on a sorted list by checking the middle element and recursively searching either the left or right half. It has faster O(log n) time complexity but requires the list to be sorted. The document also discusses binary search trees which allow for efficient search, insert, and delete operations on sorted data.

Uploaded by

sahar maqsood
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
135 views18 pages

Data Search Algorithm

The document summarizes two common search algorithms: linear search and binary search. Linear search sequentially checks each element of a list to find a target value. It has O(n) time complexity but is simple to implement. Binary search works on a sorted list by checking the middle element and recursively searching either the left or right half. It has faster O(log n) time complexity but requires the list to be sorted. The document also discusses binary search trees which allow for efficient search, insert, and delete operations on sorted data.

Uploaded by

sahar maqsood
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 18

DATA SEARCH ALGORITHM

REOPORT

PREPARED BY:

SAHANZA IRAM L4F17MSCT0001

SAHAR MAQSOOD L4F17MSCT0003

SAIRA KAHNUM L4F17MSCT0010

ISHA RASHID L4F17MSCT0011

PUNJAB GROUP OF COLLEGES


TABLE OF CONTENTS
Introduction
A search algorithm is the step by step procedure used to locate specific data among the
collections of data. Searching is considered as the most fundamental procedure in computer
science. When the data is to be searched, the difference between a fast application and a slower
one lies in the use of proper search algorithms. All search algorithms make use of a search key in
order to proceed with the procedure. Search algorithms are expected to return a success or a
failure status, usually denoted by the Boolean true or false. Different search algorithms are
available and the performance and the efficiency of them depend on the data and on the manner
on which they are used. Search cases in search algorithm can be categorized as best case, average
case, and worst case. In some algorithms all three cases can be same but in some algorithms their
might be big difference between all of them. The average behavior of the search algorithm helps
in determining the usefulness of the algorithm.

Linear Search
Linear search is a very basic and simple search algorithm. In Linear search, we search an element
or value in a given array by traversing the array from the starting, till the desired element or
value is found.

It compares the element to be searched with all the elements present in the array and when the
element is matched successfully, it returns the index of the element in the array, else it return -1.

Linear Search is applied on unsorted or unordered lists, when there are fewer elements in a list.

Features of Linear Search Algorithm

 It is used for unsorted and unordered small list of elements.


 It has a time complexity of O(n), which means the time is linearly dependent on the
number of elements, which is not bad, but not that good too.
 It has a very simple implementation.

ADVANTAGES

 For smaller lists linear search may be faster because the speed of the simple increment.
 Linear search very simplicity, resource efficient and memory efficient.
 It can operate sorted and unsorted array and link list

DISADVANTAGES

 Linear search technique is low efficient and slower than other searching algorithm.
 Not suitable for large data set.

Example:

We Search 55:
Algorithm for linear search:

Linear search (Array A, Value x)

Step 1: Set i to 1

Step 2: if i>n then go to step 7

Step 3: if A[i]=x then go to step 6

Step 4: Set i to i+1

Step 5: Go to step 2

Step 6: Print element x fund at postion i and go to step 8

Step 7: Print element not found

Step 8: Exit
IMPLEMENTATION:
OUTPUT:

Binary Search
 Binary Search is used with sorted array or list. In binary search, we follow the following
steps:

 We start by comparing the element to be searched with the element in the middle of the
list/array.
 If we get a match, we return the index of the middle element.
 If we do not get a match, we check whether the element to be searched is less or greater than
in value than the middle element.
 If the element/number to be searched is greater in value than the middle number, then we
pick the elements on the right side of the middle element(as the list/array is sorted, hence on
the right, we will have all the numbers greater than the middle number), and start again from
the step 1.
 Binary Search is useful If the element/number to be searched is lesser in value than the
middle number, then we pick the elements on the left side of the middle element, and start
again from the step 1.
 when there are large number of elements in an array and they are sorted.

 So a necessary condition for Binary search to work is that the list/array should be sorted.

Features of Binary Search:

 It is great to search through large sorted arrays.


 It has a time complexity of O(log n) which is a very good time complexity.
 It has a simple implementation.
ADVANTAGES

 The general moral is that for large lists binary search is very much faster than linear
search.
 This search technique given a searching approach on binary search tree and other tree.

DISADVANTAGES

 Binary search is not appropriate for linked list structures (no random access for the
middle term)
 Apply searching before we needed searching Algorithm.
 Not suitable for inserted/deleted a data in a searching time as a compare to other
searching algorithm.

Example:

 Step NO: 1
 Step NO: 2

 Step NO: 3
Algorithm for Binary search:

Step 1: initialize the veriable.

Step 1: Get the middle element.

Step 2:If the middle element equals to the searched value, the algorithm stops.

Step 3:Otherwise, two cases are possible.

Step 4: Searched value is less, than the middle element. In this case, go to the step 1 for the part
of the array, before middle element.

Step 5: Searched value is greater, than the middle element. In this case, go to the step 1 for the
part of the array, after middle element.

Step 6:Now, The iterations should stop when searched element is found & when sub array has
no elements. In this case, we can conclude, that searched value is not present in the array.
IMPLEMENTATION:
OUTPUT:
Comparision of linear search and binary search:

Parameter Linear Search Binary Search

Searching type Internal Searches Internal Searches


Time Complexity
1.Best Case O(1) O(1)
2.Average Case O(N ) O(log N)
3.Worst Case O(N ) O(log N)
Implementation on Easy Average
programming

Algorithm Straightforward algorithm Divide-and-Conquer


Strategy Scan on list start to end and Divide on list match on mid element
match search element one by and search element. If the search
one element is less than the middle
element, do again searching on the left
half; otherwise, search the right half.
Table and file are Unordered/Ordered Ordered
Size of table/file Suitable for small size Suitable for mid size/large size
Data Structure Array, Linked List Array
Simplicity Easy Average
Efficient Low Medium
Usefulness Easy to use and no need for Anyhow tricky algorithm and
any ordered elements. elements should be organized in order.
Lines of Code Less More

Insert operations Easily inserted at the end of Require processing to insert at its
list proper place to maintain a sorted list.
Comparison equality ordering ordering
APPLICATION OF SEARCHING ALGORITHM

Linear Search Binary Search


 Index sequential search  Microprocessor and many analog
implementations mixed signal circuits
 Recognition system  3D game
 Analysis to Hacking system  Number guessing game
 Phonebook  Searching a telephone book
 Cable and Telephone Networks for  Packing rectangles
Data Transmission  Prefix search
 Address Mapping in computer network  Client and server communication
 Find out an object in a rasterscan  Binary search Tree/Tree search
system display implementation

Conclusion:

Both linear and binary search algorithms can be useful depending on the application. When an
array is the data structure and elements are arranged in sorted order, then binary search is
preferred for quick searching. If linked list is the data structure regardless how the elements are
arranged, linear search is adopted due to unavailability of direct implementation of binary search
algorithm.

The typical Binary search algorithm cannot be employed to linked list because linked list is
dynamic in nature and it is not known where the middle element is actually assigned. Hence,
there is a requirement to design the variation of the binary search algorithm that can work on
linked list too because the binary search is faster in execution than a linear search.
Binary Search Tree:

A Binary Search Tree is a type of binary tree data structure in which the nodes are arranged in
order, hence also called as “ordered binary tree”. It’s a node-based data structure which provides
an efficient and fast way of sorting, retrieving, searching data. Binary Search Tree is a node-
based binary tree data structure which has the following properties

 Values in left sub tree less than parent


 Values in right sub tree greater than parent.

Example of binary search tree:

Basic Operations
Following are the basic operations of a tree :

 Search

 Insert

 Delete

 Traversal
 Search:

Searching in a BST always starts at the root. We compare a data stored at the root with the key
we are searching for (let us call it as toSearch). If the node does not contain the key we proceed
either to the left or right child depending upon comparison. If the result of comparison is
negative we go to the left child, otherwise - to the right child. The recursive structure of a BST
yields a recursive algorithm.

 Insertion:

The insertion procedure is quite similar to searching. We start at the root and recursively go
down the tree searching for a location in a BST to insert a new node. If the element to be inserted
is already in the tree, we are done (we do not insert duplicates). The new node will always
replace a NULL reference.

 Traversal

A traversal is a process that visits all the nodes in the tree. Since a tree is a nonlinear data
structure, there is no unique traversal. We will consider several traversal algorithms with we
group in the following two kinds

o depth-first traversal
o breadth-first traversal
There are three different types of depth-first traversals:

o PreOrder traversal - visit the parent first and then left and right children;
o InOrder traversal - visit the left child, then the parent and the right child;
o PostOrder traversal - visit left child, then the right child and then the parent.

 Deletion:
Deletion is somewhat more tricky than insertion. There are several cases to consider. A node
to be deleted (let us call it as toDelete)

 is not in a tree
 is a leaf
 has only one child
 has two children

If to Delete is not in the tree, there is nothing to delete. If to Delete node has only one child the
procedure of deletion is identical to deleting a node from a linked list - we just bypass that node
being deleted
Comparison Of Binary Tree And Binary Search Tree:

BINARY SEARCH BINARY SEARCH TREE

Binary Search Tree is a type of binary tree


Binary Tree is a specialized form of tree which
which keeps the keys in a sorted order for fast
represents hierarchical data in a tree structure.
lookup.
Binary Tree is a specialized form of tree which The value of the nodes in the left subtree are
represents hierarchical data in a tree structure. less than or equal to the value of the root
node, and the nodes to the right subtree have
values greater than or equal to the value of the
root node.
There is no relative order to how the nodes It follows a definitive order to how the nodes
should be organized. should be organized in a tree.
It’s basically a hierarchical data structure that is It’s a variant of the binary tree in which the
a collection of elements called nodes. nodes are arranged in a relative order.
It is used for fast and efficient lookup of data It is mainly used for insertion, deletion, and
and information in a tree structure. searching of elements.

You might also like