Presentation is loading. Please wait.

Presentation is loading. Please wait.

Closest Pair Given a set S = {p1, p2,..., pn} of n points in the plane find the two points of S whose distance is the smallest. Images in this presentation.

Similar presentations


Presentation on theme: "Closest Pair Given a set S = {p1, p2,..., pn} of n points in the plane find the two points of S whose distance is the smallest. Images in this presentation."— Presentation transcript:

1 Closest Pair Given a set S = {p1, p2,..., pn} of n points in the plane find the two points of S whose distance is the smallest. Images in this presentation were taken from: http://www.cs.ucf.edu/courses/cot5520/lectures.htmlhttp://www.cs.ucf.edu/courses/cot5520/lectures.html Lec15

2 Closest Pair – Naïve Algorithm Pseudo code for each pt i  S for each pt j  S and i<>j { compute distance of i, j if distance of i, j < min_dist min_dist = distance i, j } return min_dist Time Complexity– O(n 2 ) Can we do better?

3 Closest Pair – Divide & Conquer Divide the problem into two equal-sized sub problems Solve those sub problems recursively Merge the sub problem solutions into an overall solution

4 Closest Pair – Divide & Conquer Assume that we have solutions for sub problems S1, S2. How can we merge in a time-efficient way? The closest pair can consist of one point from S 1 and another from S 2 Testing all posibilities requires: O(n/2) · O(n/2)  O(n 2 ) Not good enough

5 Closest Pair – Divide & Conquer dimension d = 2 Partition two dimensional set S into subsets S 1 and S 2 by a vertical line l at the median x coordinate of S. Solve the problem recursively on S 1 and S 2. Let {p1, p2} be the closest pair in S 1 and {q1, q2} in S 2. Let  1 = distance(p1,p2) and  2 = distance(q1,q2) Let  = min(  1,  2 ) S1S1 l S2S2 22 11 p1p1 p2p2 q2q2 q1q1

6 Closest Pair – Divide & Conquer dimension d = 2 In order to merge we have to determine if exists a pair of points {p, q} where p  S 1, q  S 2 and distance(p, q) < . If so, p and q must both be within  of l. Let P 1 and P 2 be vertical regions of the plane of width  on either side of l. If {p, q} exists, p must be within P 1 and q within P 2. However, every point in S 1 and S 2 may be a candidate, as long as each is within  of l, which implies: O(n/2)  O(n/2) = O(n 2 ) Can we do better ? P1P1 lP2P2 22 q2q2 q1q1 S1S1 S2S2  11 p1p1 p2p2

7 Closest Pair – Divide & Conquer dimension d = 2 For a point p in P 1, which portion of P 2 should be checked? We only need to check the points that are within  of p. Thus we can limit the portion of P2. The points to consider for a point p must lie within   2  rectangle R. At most, how many points are there in rectangle R? P1P1 l p S1S1  P2P2 S2S2 

8 Closest Pair – Divide & Conquer dimension d = 2 How many points are there in rectangle R? Since no two points can be closer than , there can only be at most 6 points Therefore, 6  O(n/2)  O(n) Thus, the time complexity is O(n log n) P1P1 lP2P2 p  S1S1 S2S2   R How do we know which 6 points to check?

9 Closest Pair – Divide & Conquer dimension d = 2 How do we know which 6 points to check? Project p and all the points of S 2 within P 2 onto l. Only the points within  of p in the y projection need to be considered (max of 6 points). After sorting the points on y coordinate we can find the points by scanning the sorted lists. Points are sorted by y coordinates. To prevent resorting in O(n log n) in each merge, two previously sorted lists are merged in O(n). Time Complexity: O(n log n)


Download ppt "Closest Pair Given a set S = {p1, p2,..., pn} of n points in the plane find the two points of S whose distance is the smallest. Images in this presentation."

Similar presentations


Ads by Google