Files

27 lines
913 B
Python

# HumanEval/20
# Loki Mode Multi-Agent Solution
# Attempts: 1
# Passed: True
from typing import List, Tuple
def find_closest_elements(numbers: List[float]) -> Tuple[float, float]:
""" From a supplied list of numbers (of length at least two) select and return two that are the closest to each
other and return them in order (smaller number, larger number).
>>> find_closest_elements([1.0, 2.0, 3.0, 4.0, 5.0, 2.2])
(2.0, 2.2)
>>> find_closest_elements([1.0, 2.0, 3.0, 4.0, 5.0, 2.0])
(2.0, 2.0)
"""
sorted_numbers = sorted(numbers)
min_diff = float('inf')
closest_pair = (sorted_numbers[0], sorted_numbers[1])
for i in range(len(sorted_numbers) - 1):
diff = sorted_numbers[i + 1] - sorted_numbers[i]
if diff < min_diff:
min_diff = diff
closest_pair = (sorted_numbers[i], sorted_numbers[i + 1])
return closest_pair