From d87eaf6baf75c32d8c8ccec6401215e6c6c374bc Mon Sep 17 00:00:00 2001 From: unknown Date: Mon, 23 Oct 2023 15:34:18 +0530 Subject: [PATCH] Added Merge Sort in Python --- DSA_Codesheet/Python/merge_sort.py | 45 ++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 DSA_Codesheet/Python/merge_sort.py diff --git a/DSA_Codesheet/Python/merge_sort.py b/DSA_Codesheet/Python/merge_sort.py new file mode 100644 index 0000000..050fbc7 --- /dev/null +++ b/DSA_Codesheet/Python/merge_sort.py @@ -0,0 +1,45 @@ +def merge_sort(arr): + # Base case: If the list has 0 or 1 elements, it is already sorted + if len(arr) <= 1: + return arr + + # Divide the input list into two halves + middle = len(arr) // 2 + left_half = arr[:middle] + right_half = arr[middle:] + + # Recursively sort the two halves + left_half = merge_sort(left_half) + right_half = merge_sort(right_half) + + # Merge the sorted halves + return merge(left_half, right_half) + +def merge(left, right): + result = [] + left_idx, right_idx = 0, 0 + + # Compare and merge elements from the left and right halves + while left_idx < len(left) and right_idx < len(right): + if left[left_idx] < right[right_idx]: + result.append(left[left_idx]) + left_idx += 1 + else: + result.append(right[right_idx]) + right_idx += 1 + + # Append any remaining elements from the left and right halves + result.extend(left[left_idx:]) + result.extend(right[right_idx:]) + return result + +# Input: Size of the list +n = int(input()) +# Input: List of integers +arr = list(map(int, input().split())) + +# Perform Merge Sort +sorted_arr = merge_sort(arr) + +# Output: Sorted list of integers +print(" ".join(map(str, sorted_arr)))