Weekly Topic: Algorithmic Schemas
This year, we try to unite divide & conquer, greedy and searching over the state space under the topic of algorithmic schemas, as they refer to more of algorithmic thinkings than concrete algorithms.
Problem Set
Divide & Conquer
- Closest Pair: Given n (n≤106) points in a 2-D plane, find the pair of points that are closest to each other.
Binary Search
Suppose you have a sorted array, and you want to find whether a certain value x is in the array. We can start at the middle location, and check whether the value is x. If the value v is x, then we are done, else we can move to the left or right side.
Estimate the Time Complexity
It might be important to notice the time complexity of the divide and conquer algorithm.
data:image/s3,"s3://crabby-images/b7cfe/b7cfe158eba5e13550d5d8c8d45ed49fec6c8f2d" alt=""
- T(n)=k⋅T(nk)+t(n)
- ⇒T(n)=kα⋅T(1)+∑i=0α−1(ki⋅t(nki))
- ⇒T(n)=logk(n)=kα+⎧⎩⎨⎪⎪⎪⎪if t(nk)=O(1),∑i=0α−1(ki)≈n⇒O(n)if t(nk)=O(n),∑i=0α−1(n)≈αn⇒O(nlogn)
data:image/s3,"s3://crabby-images/0a039/0a03904f7bc8ec13c18bdc8414d430e6bc65f6be" alt="Master Theorem"
Greedy
Searching
- Complete search (all permutations)/state space traversal (DFS, BFS) + other topics (DP, computational geometry, graph…)/data structure (priority queue, bitmask, segment tree, …)