From 07f5067a4dc9bbcca7fd210188197d3ac4a8949e Mon Sep 17 00:00:00 2001 From: himanhsu06s <146062606+himanhsu06s@users.noreply.github.com> Date: Sat, 21 Oct 2023 00:33:24 +0530 Subject: [PATCH] Create odd_even sort.py --- odd_even sort.py | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 odd_even sort.py diff --git a/odd_even sort.py b/odd_even sort.py new file mode 100644 index 0000000..3bbc169 --- /dev/null +++ b/odd_even sort.py @@ -0,0 +1,31 @@ +def odd_even_sort(arr): + """ + Sorts the array using the Odd-Even Sort (Brick Sort) algorithm. + + Args: + arr (list): List to be sorted. + + Returns: + list: Sorted list. + + """ + n = len(arr) + is_sorted = 0 # Initially set as 0 to enter the loop + while is_sorted == 0: + is_sorted = 1 # Assume the list is sorted + for i in range(1, n - 1, 2): + if arr[i] > arr[i + 1]: + arr[i], arr[i + 1] = arr[i + 1], arr[i] + is_sorted = 0 # If swapping occurs, the list is not sorted + for i in range(0, n - 1, 2): + if arr[i] > arr[i + 1]: + arr[i], arr[i + 1] = arr[i + 1], arr[i] + is_sorted = 0 # If swapping occurs, the list is not sorted + return arr + + +# Example usage +arr = [5, 2, 3, 1, 4] +print("Original array:", arr) +sorted_arr = odd_even_sort(arr) +print("Sorted array:", sorted_arr)