-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSelectionSort.py
More file actions
48 lines (43 loc) · 1.89 KB
/
Copy pathSelectionSort.py
File metadata and controls
48 lines (43 loc) · 1.89 KB
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
47
48
import matplotlib.pyplot as plt
def visualize_sorting(number_list, compare_indices=None, color='skyblue', min_index=None,comaparing=False):
plt.clf()
if compare_indices:
colors = []
for i in range(len(number_list)):
if comaparing:
if i in compare_indices:
colors.append('magenta') # Highlight current minimum value being compared
else:
colors.append(color)
else:
if i in compare_indices:
colors.append('green')
else:
colors.append(color)
else:
colors = color
plt.bar(range(len(number_list)), number_list, color=colors)
for i in range(len(number_list)):
plt.text(i, number_list[i], str(number_list[i]), ha='center', va='bottom')
plt.xlabel('Index')
plt.ylabel('Value')
plt.title('Sorting Visualization')
plt.pause(1)
def initialize_visualization():
number_list = eval(input("Enter numbers to sort: "))
length = len(number_list)
for i in range(length - 1):
min_index = i
for j in range(i + 1, length):
if number_list[j] < number_list[min_index]:
visualize_sorting(number_list, compare_indices=[i, j], min_index=min_index,
comaparing=True) # Visualize comparison
min_index = j
if min_index != i:
number_list[i], number_list[min_index] = number_list[min_index], number_list[i]
visualize_sorting(number_list, compare_indices=[i, j], min_index=min_index) # Visualize comparison
visualize_sorting(number_list) # Visualize current state of the list
# Final visualization after sorting is complete, with all bars colored orange
visualize_sorting(number_list, color='orange')
plt.show()
print("The sorted numbers are: ", number_list)