The Problem
Imagine I am stood in an airport. Given a geographic coordinate pair, how can one efficiently determine which airport I am stood in?
Inputs
- A coordinate pair
(x,y)
representing the location I am stood at. - A set of coordinate pairs
[(a1,b1), (a2,b2)...]
where each coordinate pair represents one airport.
Desired Output
A coordinate pair (a,b)
from the set of airport coordinate pairs representing the closest airport to the point (x,y)
.
Inefficient Solution
Here is my inefficient attempt at solving this problem. It is clearly linear in the length of the set of airports.
shortest_distance = None
shortest_distance_coordinates = None
point = (50.776435, -0.146834)
for airport in airports:
distance = compute_distance(point, airport)
if distance < shortest_distance or shortest_distance is None:
shortest_distance = distance
shortest_distance_coordinates = airport
The Question
How can this solution be improved? This might involve some way of pre-filtering the list of airports based on the coordinates of the location we are currently stood at, or sorting them in a certain order beforehand.
compute_distance()
, which I doubt since you are probably just doing Haversine distance) – Dmitry Torba