-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathbubble_sort.py
More file actions
39 lines (30 loc) · 1013 Bytes
/
bubble_sort.py
File metadata and controls
39 lines (30 loc) · 1013 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
#!/usr/bin/env python3
"""
Simple bubble sort implementation in Python.
"""
def bubble_sort(arr):
"""
Sort an array using the bubble sort algorithm.
Args:
arr: List of comparable elements to sort
Returns:
Sorted list (original array is modified in-place)
"""
n = len(arr)
# Make a copy to avoid modifying the original
arr = arr.copy()
# Traverse through all array elements
for i in range(n):
# Last i elements are already in place
for j in range(0, n - i - 1):
# Traverse the array from 0 to n-i-1
# Swap if the element found is greater than the next element
if arr[j] > arr[j + 1]:
arr[j], arr[j + 1] = arr[j + 1], arr[j]
return arr
if __name__ == "__main__":
# Example usage
test_array = [64, 34, 25, 12, 22, 11, 90]
print(f"Original array: {test_array}")
sorted_array = bubble_sort(test_array)
print(f"Sorted array: {sorted_array}")