Programming in Python
BEES 2021
data:image/s3,"s3://crabby-images/2a058/2a05811c24f527ab47d89f87e470982e9f3df12c" alt=""
Agenda
- A couple of simple list algorithms:
- Linear search
- Binary search
- A very brief introduction to runtime analysis and Big-O Notation
- Dictionaries
- Set
Linear search
- Linear search or sequential search is a search method for finding an element within a list
- It sequentially checks each element of the list until a match is found or the whole list has been searched
data:image/s3,"s3://crabby-images/c8a2a/c8a2a867ce44839251b0bd989e7db8fc2d83d150" alt=""
Linear search example
Binary search
-
In binary search, for a sorted list, we start from the middle of the list and then check if the middle word is less than, equal to or greater than the search query string.
-
Based on the result we can generally halve the size of the search, and so recursively solve the problem.
data:image/s3,"s3://crabby-images/01a8f/01a8f36eebd3ecd041691fcae15b77bc1194c287" alt=""
binary search example
data:image/s3,"s3://crabby-images/e1fe6/e1fe65719cdf44d46360a904fc4af4954cb17265" alt=""
data:image/s3,"s3://crabby-images/060d5/060d55cb2c3ae8bf3a2e6c2c23e1fb54f5f16e6d" alt=""
Linear vs binary search
dictionaries
data:image/s3,"s3://crabby-images/dbd65/dbd65a3657280cc948d3f39197868d4c3020b994" alt=""
dictionary
0
Advanced issues found▲
- Dictionary is an unordered collection of key-value pairs
- Each value can be accessed using its key
- Key can be any immutable object
eng2sp = {}
eng2sp["one"] = "uno"
eng2sp["two"] = "dos"
sp2eng = {"uno":"one", "dos":"two"}
data:image/s3,"s3://crabby-images/8709f/8709ff2432bd71a41c136f130c382f22e6e1d483" alt=""
practice with dictionary
why use dictionaries?
- Convenient
- Fast
- The cost of looking up a key in the dictionary is O(1) comparing to searching a list in O(N)
- Removal and update operations are also O(1)
word counting
sets
set
0
Advanced issues found▲
- Set is a collection of unique objects
- Objects in set are not ordered
x = set(["Internet", "Radio", "TV"])
print(x)
# Prints {'Internet', 'TV', 'Radio'}
y = {"Internet","Radio","Internet"}
print(y)
# Prints {'Internet', 'Radio'}
set example
Lecture 9 challenge
Questions?
data:image/s3,"s3://crabby-images/16b83/16b839b58075880fe4b4838aff7016e0852c33f4" alt=""
BEES - Lecture 9
By Narges Norouzi
BEES - Lecture 9
- 481