Download presentation
Presentation is loading. Please wait.
1
3.3 Fundamentals of data representation
3.1.3 Searching algorithms 2 Lesson
2
How many records might need to be searched through?
Think about this… A software company is asked to create a program for searching through a database of mobile-phone records for everyone owning a phone in the UK so that any individual’s number can be retrieved. How many records might need to be searched through? It is reasonable to suggest that each individual in the UK probably owns at least one mobile phone or even two. Any answer between 50,000,000 to 200,000,000 records would be reasonable. Using a linear search it would be easy to code, but using a linear search would be very inefficient/slow using such a huge database.
3
Objectives Understand and explain how the binary search algorithm works Compare and contrast linear and binary search algorithms
4
Introduction to binary searching
We looked previously at performing a linear search and saw that it can be inefficient. A more efficient algorithm is the binary search.
5
Definition of a binary search
A method for searching data that splits datasets into two components repeatedly until the search term is located. What is a dataset? A collection of data, e.g. a table in a database. Why do we use the word binary? Binary implies two states – here we talk about splitting a dataset into two.
6
Before we can start… A binary search can only work with an ordered list. An ordered list is one where the fields are sorted in a preferred order, e.g. by numerical or alphabetical order. Besides the list being sorted, we will also need to know its size to enable us to identify the middle of the list.
7
Watch this video youtube.com/watch?v=JQhciTuD3E8&nohtml5=False
Continuation of the video from last lesson. Watch from 3:12 minutes to 6:31 minutes.
8
Binary search algorithm
Store SearchTerm StartPointer <- 1 EndPointer <- DataSetSize Do MidPointer <- (StartPointer + EndPointer ) / 2 (round answer down) If Record[MidPointer] < SearchTerm Then StartPointer <- MidPointer + 1 End If If Record[MidPointer] > SearchTerm Then EndPointer <- MidPointer – 1 Until Record[MidPointer] = SearchTerm OR StartPointer = EndPointer Print this slide.
9
Comparing linear and binary searches
A linear search has an algorithm that is easier to understand, whereas the binary search algorithm is more complex. The binary search will be much quicker than a linear search – particularly where the volume of data being searched is large. One frequently asked question is ‘why is the binary search algorithm better if it requires the data to be sorted first? Surely that is a time-consuming process?’ The answer here is that yes, sorting the data will incur a processing overhead but that you only need do the sort once, you can do as many searches as you want thereafter and in reality, that is what will happen. A linear search will always be slower by comparison.
10
To round things off… Recap with BBC Bitesize: bbc.co.uk/education/guides/zgr2mp3/revision/2
11
The ordered list we are going to search is shown below:
Position of item in list [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 The extension task starts here. Value of item [4]
12
Binary search algorithm
Store SearchTerm StartPointer <- 1 EndPointer <- DataSetSize Do MidPointer <- (StartPointer + EndPointer ) / 2 (round answer down) If Record[MidPointer] < SearchTerm Then StartPointer <- MidPointer + 1 End If If Record[MidPointer] > SearchTerm Then EndPointer <- MidPointer – 1 Until Record[MidPointer] = SearchTerm OR StartPointer = EndPointer Extension task. A printable version is available in the accompanying Word document.
13
Data area covered during each loop
Position [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] Loop #1 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 Loop #2 Loop #3 Loop #4 Loop #5 Extension task. A printable version is available in the accompanying Word document.
14
Trace table DataSetSize SearchTerm StartPointer EndPointer MidPointer Record[MidPointer] < SearchTerm Record[MidPointer] > SearchTerm [END] Record[MidPointer] = SearchTerm OR StartPointer = EndPointer Only one of these conditions should be met for each iteration. Fixed 21 Input 43 Initial 1 Loop 1 12 ( = 22)/2 = 11 18 < 43 Loop 2 15 ( = 33)/2 = 16* 45 > 43 Loop 3 14 ( = 27)/2 = 13* 26 < 43 Loop 4 ( = 27)/2 = 14* 29 < 43 Loop 5 ( = 30)/2 = 15* Met! Record[MidPointer] = SearchTerm * = Rounded down Extension task. A printable version is available in the accompanying Word document.
15
Following the binary search algorithm 1
Loop #1 – [On entering loop, StartPointer = 1, EndPointer = 21, Search term = 43] Midpoint <- Cell [11] = 18 Condition now met has requirement = Change StartPointer Start point <- 12 [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 Extension task. Please refer to printable version of slides 12–14 in the accompanying Word document.
16
Following the binary search algorithm 2
Loop #2 Midpoint <- Cell [16] = 45 Condition now met has requirement = Change EndPointer End point <- 15 [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 Extension task.
17
Following the binary search algorithm 3
Loop #3 Midpoint <- Cell [13] = 26 Condition has now met requirement = Change StartPointer Start point <- 14 [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 Extension task.
18
Following the binary search algorithm 4
Loop #4 Midpoint <- Cell [14] = 29 Condition has now met requirement = Change StartPointer Start point <- 15 [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 Extension task.
19
Following the binary search algorithm 5
Loop #5 Midpoint <- Cell [15] = 43 Condition met = Search term matched Exit program! [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] 3 4 5 7 8 9 11 15 17 18 19 26 29 43 45 47 49 67 78 99 Extension task.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.