8.1.4
Search Algorithms
Search Algorithms
Search Algorithms
Searching is a classic computer science problem. It involves finding a certain value in a set of other values.
data:image/s3,"s3://crabby-images/e472f/e472fa062b23363aa564924c8dc701b888ee0865" alt="Illustrative background for Search algorithms"
data:image/s3,"s3://crabby-images/e472f/e472fa062b23363aa564924c8dc701b888ee0865" alt="Illustrative background for Search algorithms ?? "content"
Search algorithms
Search algorithms
- A search algorithm is a set of instructions for finding a specific item of data within a data set.
- Computer systems can store and process billions of pieces of data so it is vital that computers can find the information they need efficiently.
data:image/s3,"s3://crabby-images/2eaf1/2eaf151dda9d7967d9f02a38dc9cc730c497800e" alt="Illustrative background for Effective searching"
data:image/s3,"s3://crabby-images/2eaf1/2eaf151dda9d7967d9f02a38dc9cc730c497800e" alt="Illustrative background for Effective searching ?? "content"
Effective searching
Effective searching
- An effective search is one which will always either find the solution or determine that the target data is not present.
data:image/s3,"s3://crabby-images/f046a/f046a1c8fd97ccada9cc2db70eaab45c20ef81a2" alt="Illustrative background for Efficient searching"
data:image/s3,"s3://crabby-images/f046a/f046a1c8fd97ccada9cc2db70eaab45c20ef81a2" alt="Illustrative background for Efficient searching ?? "content"
Efficient searching
Efficient searching
- An efficient search will find the solution quickly regardless of its location within the data set.
data:image/s3,"s3://crabby-images/43aff/43aff9ae61a17a88b75f3a061fbbf931f530d0e3" alt="Illustrative background for Examples of search algorithms"
data:image/s3,"s3://crabby-images/43aff/43aff9ae61a17a88b75f3a061fbbf931f530d0e3" alt="Illustrative background for Examples of search algorithms ?? "content"
Examples of search algorithms
Examples of search algorithms
- Two common search algorithms are:
- Linear search.
- Binary search.
Linear Search
Linear Search
Linear search is one of the simplest searching algorithms.
data:image/s3,"s3://crabby-images/9f77f/9f77fa5c32a3c7c410b5f856e702f0f27d2963ce" alt="Illustrative background for The concept"
data:image/s3,"s3://crabby-images/9f77f/9f77fa5c32a3c7c410b5f856e702f0f27d2963ce" alt="Illustrative background for The concept ?? "content"
The concept
The concept
- If you were looking for a specific piece of paper in a stack of papers, then one way to find it would be to work from the top of the stack to the bottom, checking each paper on the way.
- This is exactly how linear search works.
data:image/s3,"s3://crabby-images/58812/5881244952a88fa38e0b766c5c8386badc8dc18d" alt="Illustrative background for In English"
data:image/s3,"s3://crabby-images/58812/5881244952a88fa38e0b766c5c8386badc8dc18d" alt="Illustrative background for In English ?? "content"
In English
In English
- Check the first item in the dataset:
- If it is what we are looking for, return it.
- Check the second item in the dataset:
- If it is what we are looking for, return it.
- Continue for rest of items.
- If we reach the end of the data set, then the item was not in our data set.
data:image/s3,"s3://crabby-images/13a20/13a20f995d441966e4131e936d86e6d04d865892" alt="Illustrative background for Pros and cons of linear search"
data:image/s3,"s3://crabby-images/13a20/13a20f995d441966e4131e936d86e6d04d865892" alt="Illustrative background for Pros and cons of linear search ?? "content"
Pros and cons of linear search
Pros and cons of linear search
- Pros:
- Very easy to implement.
- Cons:
- Slow on a long list.
Binary Search
Binary Search
Binary search is an example of a divide-and-conquer algorithm.
data:image/s3,"s3://crabby-images/e6c80/e6c80785e75359568a71bf3ef2135688cf8c9a85" alt="Illustrative background for The concept"
data:image/s3,"s3://crabby-images/e6c80/e6c80785e75359568a71bf3ef2135688cf8c9a85" alt="Illustrative background for The concept ?? "content"
The concept
The concept
- If you try to find a certain page in a book, it's unlikely that you check every page on the way.
- You are more likely to split the book in two, then see if the page you need is before or after the split, and repeat.
- This is the concept behind the binary search.
data:image/s3,"s3://crabby-images/58812/5881244952a88fa38e0b766c5c8386badc8dc18d" alt="Illustrative background for In English"
data:image/s3,"s3://crabby-images/58812/5881244952a88fa38e0b766c5c8386badc8dc18d" alt="Illustrative background for In English ?? "content"
In English
In English
- Find the middle of the dataset.
- If the middle value is greater than the target then:
- Repeat on the first half of dataset.
- If the middle value is lesser than the target then:
- Repeat on the second half of dataset.
- If the middle value is the target:
- We found it!
- Stop repeating once the size of our dataset is zero.
data:image/s3,"s3://crabby-images/8092f/8092f8588e8fb3dbf7dab91a474ffd3fd52a45b3" alt="Illustrative background for Pros and cons of binary search"
data:image/s3,"s3://crabby-images/8092f/8092f8588e8fb3dbf7dab91a474ffd3fd52a45b3" alt="Illustrative background for Pros and cons of binary search ?? "content"
Pros and cons of binary search
Pros and cons of binary search
- Pros:
- Faster than linear search on a large dataset.
- Cons:
- Dataset must be sorted before starting.
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
Jump to other topics
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
data:image/s3,"s3://crabby-images/9220a/9220a64e707af924249b072e9ddcfcd413526ea9" alt="Go student ad image"
Unlock your full potential with GoStudent tutoring
Affordable 1:1 tutoring from the comfort of your home
Tutors are matched to your specific learning needs
30+ school subjects covered