data:image/s3,"s3://crabby-images/2a196/2a1963a204991a05c557974f6eaff64d1236ba53" alt=""
Linear SearchConcept
Iterate through the array and compare each element to the target element until found
Runtime
O(n)
Video Explanation
Binary Search
Concept
Pick a middle point and determine which direction to look for the target, repeat the process on that side of the array (Note: only works for a fully-sorted array)
Runtime
O(lgn)
Video Explanation
Example Problems
data:image/s3,"s3://crabby-images/83b56/83b56ecab92df73d2c8ec074c9a75125a6f8a95b" alt=""
Breadth-First Search
Concept
Srch a tree/graph, looking at the nodes closest to the start first
Implementation
Uses a Queue (FIFO) to search nodes found earlier before nodes found recently
Runtime
O(V+E)
Video Explanation
Example Problems
data:image/s3,"s3://crabby-images/8bfca/8bfca34cd3b03b181f53b55aaa1308c5770a3d58" alt=""
Depth-First Search
Concept
Search a tree/graph, looking at the nodes furthest from the start first
Implementation
Uses a Stack (LIFO) to search nodes found recently before nodes found earlier
Runtime
O(V+E)
Video Explanation
Example Problems
Dijkstra's Algorithm
Concept
Find the shortest path between two vertices in a graph
Implementation
Uses a Priority Queue to repeatedly select the nearest unvisited vertex and calculate the distance to all neighboring vertices (until the Goal is reached)
Runtime
O(V+E)
Video Explanation
Topological Sort
Concept
Order a graph’s vertices (must be a Directed Acyclic Graph) so that for each directed edge <u,v>, u comes before v in the ordering
Implementation
Repeatedly search the graph for vertices with no incoming edges, add them to the ordering, and remove them from future consideration
Runtime
O(V+E)
Video Explanation
A* SearchConcept
Improve on Dijkstra's by using heuristics to select the best path to explore next
Implementation
Uses a Priority Queue and some user-specified heuristic (straight line distance, Manhattan distance, etc.)
Runtime
O(V+E)