-
Notifications
You must be signed in to change notification settings - Fork 78
/
Copy pathlsd.py
45 lines (39 loc) · 949 Bytes
/
lsd.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
"""
Execution: python lsd.py < input.txt
Data files: https://algs4.cs.princeton.edu/51radix/words3.txt
% python lsd.py < words3.txt
all
bad
bed
bug
dad
...
yes
yet
zoo
"""
class LSD:
R = 256
@classmethod
def sort(cls, a, w):
n = len(a)
aux = ['' for _ in range(n)]
for d in range(w-1, -1, -1):
count = [0 for _ in range(cls.R+1)]
for i in range(n):
count[ord(a[i][d])+1] += 1
for r in range(cls.R):
count[r+1] += count[r]
for i in range(n):
aux[count[ord(a[i][d])]] = a[i]
count[ord(a[i][d])] += 1
for i in range(n):
a[i] = aux[i]
if __name__ == '__main__':
import sys
words = []
for line in sys.stdin:
words.extend(line.split())
LSD.sort(words, len(words[0]))
for item in words:
print(item)