Skip to content

Commit

Permalink
Merge pull request #379 from ruchikakengal/solutions-adding-
Browse files Browse the repository at this point in the history
Add Sorting problems
  • Loading branch information
PRIYESHSINGH24 authored Jan 20, 2025
2 parents 3528e6b + f1525ad commit cccaaf1
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 0 deletions.
7 changes: 7 additions & 0 deletions Geeks For Geeks/Sorting problems/Bubble Sort.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
def bubble_sort(arr):
n = len(arr)
for i in range(n):
for j in range(0, n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
return arr
9 changes: 9 additions & 0 deletions Geeks For Geeks/Sorting problems/Insertion Sort.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
def insertion_sort(arr):
for i in range(1, len(arr)):
key = arr[i]
j = i - 1
while j >= 0 and arr[j] > key:
arr[j + 1] = arr[j]
j -= 1
arr[j + 1] = key
return arr
23 changes: 23 additions & 0 deletions Geeks For Geeks/Sorting problems/Merge Sort.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
def merge_sort(arr):
if len(arr) <= 1:
return arr

mid = len(arr) // 2
left = merge_sort(arr[:mid])
right = merge_sort(arr[mid:])

return merge(left, right)

def merge(left, right):
result = []
i = j = 0
while i < len(left) and j < len(right):
if left[i] < right[j]:
result.append(left[i])
i += 1
else:
result.append(right[j])
j += 1
result.extend(left[i:])
result.extend(right[j:])
return result
9 changes: 9 additions & 0 deletions Geeks For Geeks/Sorting problems/Selection Sort.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
def selection_sort(arr):
n = len(arr)
for i in range(n):
min_idx = i
for j in range(i+1, n):
if arr[j] < arr[min_idx]:
min_idx = j
arr[i], arr[min_idx] = arr[min_idx], arr[i]
return arr

0 comments on commit cccaaf1

Please sign in to comment.