forked from TheAlgorithms/Python
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmax_min.py
More file actions
46 lines (35 loc) · 915 Bytes
/
max_min.py
File metadata and controls
46 lines (35 loc) · 915 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
"""
Find the maximum and minimum elements in a list.
Source: https://en.wikipedia.org/wiki/Maximum_and_minimum
>>> find_max_min([4, 2, 9, 1, 7])
(9, 1)
>>> find_max_min([-5, -10, 0, 5])
(5, -10)
>>> find_max_min([42])
(42, 42)
>>> find_max_min([])
"""
def find_max_min(arr):
"""
Returns the maximum and minimum elements of a list.
Parameters:
arr (list): The list of numbers.
Returns:
tuple: (maximum, minimum)
Raises:
ValueError: If the list is empty.
"""
if not arr:
raise ValueError("find_max_min() arg is an empty list")
maximum = max(arr)
minimum = min(arr)
return maximum, minimum
if __name__ == "__main__":
examples = [
[4, 2, 9, 1, 7],
[-5, -10, 0, 5],
[42],
]
for arr in examples:
max_val, min_val = find_max_min(arr)
print(f"For list {arr}, maximum: {max_val}, minimum: {min_val}")