W równych odcinkach wzdłuż torów leży n miejscowości. Podana jest lista miast w których jest stacja kolejowa (nie musi być posortowana). Jaka jest największa odległość między stacją, a dowolnym miastem? Miasta indeksujemy od 0 do n - 1.
Przypuśćmy, że wzdłuż torów leży n = 8 miejscowości. Stacje mieszczą się w miastach 2, 4 i 7 co przedstawia poniższy schemat:
W tym przypadku maksymalna odległość wynosi 2, ponieważ osoby mieszkające w miejscowości 0 najbliższą stację mają dwie miejscowości dalej. Miejscowości 1, 3, 5 oraz 6 mają stacje "po sąsiedzku" w odległości 1.
W celu rozwiązania podanego problemu należy zauważyć, że najdalsza odległość pomiędzy dwoma miejscowościami to odległość pomiędzy nimi podzielona przez 2. Część ułamkowa jest odrzucana. Jednak dla pierwszej i ostatniej miejscowości należy brać pełną odległość do najbliższej stacji.
Poniższa funkcja NajdalszaOdleglosc() używa przedstawionego wyżej algorytmu do obliczenia najdalszej odległości. Jako argumenty przyjmuje ile jest miejscowości oraz listę indeksów miejscowości, gdzie mieści się stacja.
Początkowo maksymalna odległość wynosi tyle co odległość z miejscowości 0 do najbliższej tj. pierwszej stacji na trasie. Następnie pomiędzy każdymi kolejnymi stacjami jest obliczana odległość. Za każdym razem maksymalna odległość to maksimum z nowo obliczonej odległości oraz dotychczas znalezionej.
Poniższy fragment kodu wczytuje od użytkownika potrzebne dane, a następnie wypisuje obliczoną maksymalną odległość.