forked from HarshCasper/NeoAlgo
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Bubble_Sort.py
44 lines (36 loc) · 1.17 KB
/
Bubble_Sort.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
39
40
41
42
43
44
'''
bubble_sort() function uses an iterative approach sort the array in increasing
order passed as an argument. It compares adjacent elements and swappes them if
there is any larger element before the smaller element. After the first pass,
the most heaviest element shifts to the last position.
The flag is used to check if any swapping is performed or not. If no swapping is
done, the loop breaks as the array is already sorted.
Return Type: No return type as lists are mutable
'''
def bubble_sort(Array):
n = len(Array)
for i in range(n-1):
flag = True
for j in range(n-i-1):
if Array[j] > Array[j+1]:
flag = False
Array[j], Array[j+1] = Array[j+1], Array[j]
if flag:
break
if __name__ == "__main__":
print("Enter the elements of the list to be sorted: ")
Array = [int(x) for x in input().split(" ")]
bubble_sort(Array)
print("List after sorting: ")
for i in Array:
print(i, end=" ")
'''
Sample Input:
Enter the elements of the list to be sorted:
2 5 1 6 3 9 10 8
Sample Output:
List after sorting:
1 2 3 5 6 8 9 10
Time Complexity: O(n^2)
Space Complexity: O(1)
'''