PROBLEM SET 1: GETTING STARTED
These problem below will help you gain a familiarity with asymptotic notation and the basics of
algorithmic design and analysis.
Problem 1: Counting sort
The counting sort algorithm is an algorithm for sorting an array of integers, each of which happens
to fall in the range [0, U) for some number U. Prove that counting sort actually runs in time (n +
U).Here is pseudocode for counting sort:
Problem 2: Asymptotic notation
For each of these problems, if you want to prove a result, you should offer a formal mathematical
proof using the rigorous definition O, Q, or 0 notation. If you want to disprove a result, you can
give a counterexample, but should prove why your counterexample is valid.
Assume all functions listed below have N as their domain and codomain.
i. Prove or disprove: For any functions and , () +() = (max{(), ()})
ii. Prove or disprove: If () = (()), 2
()
= (2
()
)
iii. Prove or disprove: ! = (2
)
Problem 3: Searching a grid
Suppose that you are given an m x n grid of integers where each row and each column are in sorted
order (we'll call this a sorted grid). For example:
procedure countingSort(array A, int U)
1. let counts = new array of size U
2. for i = 0 to U - 1:
3. counts[i] = 0
4. for i = 0 to length(A) - 1:
5. counts[A[i]] = counts[A[i]] + 1
6. let index = 0
7. for i = 0 to U - 1:
8. for j = 0 to counts[i] - 1:
9. A[index] = i
10. index = index + 1
10 12 13 21 32 34 43 51 67 69 90 101 133
16 21 23 26 40 54 65 67 68 71 99 110 150
21 23 31 33 54 58 74 77 97 98 110 111 150
32 46 59 65 74 88 99 103 113 125 137 149 159
53 75 96 115 124 131 132 136 140 156 156 157 161
84 86 98 145 146 151 173 187 192 205 206 208 219
135 141 153 165 174 181 194 208 210 223 236 249 258
216 220 222 225 234 301 355 409 418 446 454 460 541
Design an O(m + n)-time algorithm that, given as input a sorted m x n grid and an integer, returns
whether or not that integer is contained in the grid. Your algorithm should use only O(1) additional
space. Then:
i. Describe your algorithm.
ii. Prove that your algorithm is correct.
iii. Prove that your algorithm runs in time O(m + n) and uses O(1) additional space.
Problem 4: Emergency Route Planning
Suppose that you have an undirected graph representing a city's transportation network. Each edge
represents a street (which for now we'll assume is a two-way street), and each node represents an
intersection.
Certain intersections in the city are hospitals, and you are interested in finding, for each intersec-
tion, the distance that intersection is from the nearest hospital, as measured by the number of
edges in the path from that intersection to the nearest hospital. For example, given the following
transportation network, where black nodes represent hospitals, the distances are as follows
Let n be the number of nodes in the transportation network and let m be the number of edges.
Although in the above example there were exactly three hospitals, any number of nodes in the
grid can be hospitals.
Design an O(m + n)-time algorithm for computing the distance from each intersection to the
closest hospital. Note that your algorithm's asymptotic runtime should not depend on the total
number of hospitals. Then
i. Describe your algorithm.
ii. Prove that your algorithm is correct.
iii. Prove that your algorithm runs in time O(m + n).