-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmaxmin.py
38 lines (27 loc) · 1023 Bytes
/
maxmin.py
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
def conventional_min_max(arr):
if not arr:
return None, None
min_element = arr[0]
max_element = arr[0]
for num in arr:
if num < min_element:
min_element = num
if num > max_element:
max_element = num
return min_element, max_element
def divide_and_conquer_min_max(arr, low, high):
if low == high:
return arr[low], arr[low]
mid = (low + high) // 2
left_min, left_max = divide_and_conquer_min_max(arr, low, mid)
right_min, right_max = divide_and_conquer_min_max(arr, mid + 1, high)
return min(left_min, right_min), max(left_max, right_max)
def find_min_max(arr):
if not arr:
return None, None
return divide_and_conquer_min_max(arr, 0, len(arr) - 1)
arr = [3, 1, 5, 7, 2, 9, 8]
min_elem, max_elem = conventional_min_max(arr)
print(f"Conventional Approach - Min: {min_elem}, Max: {max_elem}")
min_elem, max_elem = find_min_max(arr)
print(f"Divide & Conquer Approach - Min: {min_elem}, Max: {max_elem}")