Skip to content

Commit e8a7e4f

Browse files
committed
added max and min algo
1 parent 9372040 commit e8a7e4f

File tree

1 file changed

+45
-0
lines changed

1 file changed

+45
-0
lines changed
Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
"""
2+
Find the maximum and minimum elements in a list.
3+
Source: https://en.wikipedia.org/wiki/Maximum_and_minimum
4+
5+
>>> find_max_min([4, 2, 9, 1, 7])
6+
(9, 1)
7+
>>> find_max_min([-5, -10, 0, 5])
8+
(5, -10)
9+
>>> find_max_min([42])
10+
(42, 42)
11+
>>> find_max_min([])
12+
"""
13+
14+
def find_max_min(arr):
15+
"""
16+
Returns the maximum and minimum elements of a list.
17+
18+
Parameters:
19+
arr (list): The list of numbers.
20+
21+
Returns:
22+
tuple: (maximum, minimum)
23+
24+
Raises:
25+
ValueError: If the list is empty.
26+
"""
27+
28+
if not arr:
29+
raise ValueError("find_max_min() arg is an empty list")
30+
31+
maximum = max(arr)
32+
minimum = min(arr)
33+
return maximum, minimum
34+
35+
36+
if __name__ == "__main__":
37+
examples = [
38+
[4, 2, 9, 1, 7],
39+
[-5, -10, 0, 5],
40+
[42],
41+
]
42+
43+
for arr in examples:
44+
max_val, min_val = find_max_min(arr)
45+
print(f"For list {arr}, maximum: {max_val}, minimum: {min_val}")

0 commit comments

Comments
 (0)