Ниже приведена программа, предназначенная для сортировки по методу сортировки по методу radix, но для каждого входа не отображается правильный вывод.Программа Radix Sort в python
def RadixSort(A):
RADIX = 10
maxLength = False
tmp , placement = -1, 1
while not maxLength:
maxLength = True
buckets = [list() for _ in range(RADIX)]
for i in A:
tmp = i/placement
buckets[tmp % RADIX].append(i)
if maxLength and tmp > 0:
maxLength = False
a = 0
for b in range(RADIX):
buck = buckets[b]
for i in buck:
A[a] = i
a += 1
placement *= RADIX
return A
A = []
n = input("Enter the numebr of elements you want to sort : ")
n = int(n)
print("Enter the numbers : \n")
for i in range(0, n):
num = int(input())
A.append(num)
print(RadixSort(A))
несколько примеров ввода-вывода случаев/приведены ниже: -
Enter the numebr of elements you want to sort : 5
Enter the numbers :
5
4
3
2
1
[1, 2, 3, 4, 5]
Здесь мы получаем правильный вывод, но при рассмотрении дела ниже мы получим неверные результаты
Enter the numebr of elements you want to sort : 9
Enter the numbers :
50
41
700
96
4
00
4
6
852
[50, 700, 0, 41, 852, 4, 4, 96, 6]
I Я пытаюсь понять это, но не могу найти точную проблему.
Это питон 2 или 3? –
Наиболее очевидной стратегией отладки является распечатка списка после каждого прохода через цикл и/или список ковшей. – Hurkyl