2017-02-25 23:06:58 +08:00
|
|
|
def radixsort(lst):
|
|
|
|
RADIX = 10
|
|
|
|
maxLength = False
|
|
|
|
tmp , placement = -1, 1
|
2017-09-30 05:47:24 +08:00
|
|
|
|
2017-02-25 23:06:58 +08:00
|
|
|
while not maxLength:
|
|
|
|
maxLength = True
|
|
|
|
# declare and initialize buckets
|
|
|
|
buckets = [list() for _ in range( RADIX )]
|
2017-09-30 05:47:24 +08:00
|
|
|
|
2017-02-25 23:06:58 +08:00
|
|
|
# split lst between lists
|
|
|
|
for i in lst:
|
2017-09-30 05:47:24 +08:00
|
|
|
tmp = i // placement
|
2017-02-25 23:06:58 +08:00
|
|
|
buckets[tmp % RADIX].append( i )
|
|
|
|
if maxLength and tmp > 0:
|
|
|
|
maxLength = False
|
2017-09-30 05:47:24 +08:00
|
|
|
|
2017-02-25 23:06:58 +08:00
|
|
|
# empty lists into lst array
|
|
|
|
a = 0
|
|
|
|
for b in range( RADIX ):
|
|
|
|
buck = buckets[b]
|
|
|
|
for i in buck:
|
|
|
|
lst[a] = i
|
|
|
|
a += 1
|
2017-09-30 05:47:24 +08:00
|
|
|
|
2017-02-25 23:06:58 +08:00
|
|
|
# move to next
|
|
|
|
placement *= RADIX
|