-
Notifications
You must be signed in to change notification settings - Fork 0
/
ordbok.py
55 lines (50 loc) · 1.34 KB
/
ordbok.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
46
47
48
49
50
51
52
53
54
55
from sys import stdin, stderr
import traceback
class Node:
def __init__(self):
self.barn = {}
self.posi = []
def bygg(ordliste):
# START IKKE-UTDELT KODE
toppNode = Node()
for (ord, posisjon) in ordliste:
node = toppNode
for bokstav in ord:
if not bokstav in node.barn:
node.barn[bokstav] = Node()
node = node.barn[bokstav]
node.posi.append(posisjon)
return toppNode
# SLUTT IKKE-UTDELT KODE
def posisjoner(ord, indeks, node):
# START IKKE-UTDELT KODE
if indeks >= len(ord):
posi = node.posi
elif ord[indeks] == "?":
posi = []
for barn in node.barn.values():
posi += posisjoner(ord, indeks + 1, barn)
elif ord[indeks] in node.barn:
posi = posisjoner(ord, indeks + 1, node.barn[ord[indeks]])
else:
posi = []
return posi
# SLUTT IKKE-UTDELT KODE
try:
ord = stdin.readline().split()
ordliste = []
pos = 0
for o in ord:
ordliste.append( (o,pos) )
pos += len(o) + 1
toppnode = bygg(ordliste)
for sokeord in stdin:
sokeord = sokeord.strip()
print sokeord + ":",
posi = posisjoner(sokeord, 0, toppnode)
posi.sort()
for p in posi:
print p,
print
except:
traceback.print_exc(file=stderr)