Skip to content
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
58 changes: 58 additions & 0 deletions sorts/radix__sort.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
# Python program for implementation of Radix Sort

# A function to do counting sort of arr[] according to
# the digit represented by exp.
def counting_sort(arr, exp1):
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

def defining counting_sort

n = len(arr)

# The output array elements that will have sorted arr
output = [0] * (n)

# initialize count array as 0
count = [0] * (10)

# Store count of occurrences in count[]
for i in range(0, n):

Check failure on line 15 in sorts/radix__sort.py

View workflow job for this annotation

GitHub Actions / ruff

Ruff (PIE808)

sorts/radix__sort.py:15:20: PIE808 Unnecessary `start` argument in `range`
index = arr[i] / exp1
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Initialising variables and comments to explain code.

count[int((index) % 10)] += 1

# Change count[i] so that count[i] now contains actual
# position of this digit in output array
for i in range(1, 10):
count[i] += count[i - 1]

# Build the output array
i = n - 1
while i >= 0:
index = arr[i] / exp1
output[count[int((index) % 10)] - 1] = arr[i]
count[int((index) % 10)] -= 1
i -= 1

# Copying the output array to arr[],
# so that arr now contains sorted numbers
i = 0
for i in range(0, len(arr)):

Check failure on line 35 in sorts/radix__sort.py

View workflow job for this annotation

GitHub Actions / ruff

Ruff (PIE808)

sorts/radix__sort.py:35:20: PIE808 Unnecessary `start` argument in `range`
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Initialising for loop to be ran

arr[i] = output[i]


# Method to do Radix Sort
def radix_sort(arr):
# Find the maximum number to know number of digits
max1 = max(arr)

# Do counting sort for every digit. Note that instead
# of passing digit number, exp is passed. exp is 10^i
# where i is current digit number
exp = 1
while max1 // exp > 0:
counting_sort(arr, exp)
exp *= 10


# Driver code to test above
arr = [170, 45, 75, 90, 802, 24, 2, 66]
radix_sort(arr)

for i in range(len(arr)):
print(arr[i], end=" ")
Loading