forked from PratikSavla/compiler-design-lab
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathex4.py
58 lines (52 loc) · 1.53 KB
/
ex4.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
56
57
58
from itertools import takewhile
def groupby(ls):
d = {}
ls = [ y[0] for y in rules ]
initial = list(set(ls))
for y in initial:
for i in rules:
if i.startswith(y):
if y not in d:
d[y] = []
d[y].append(i)
return d
def prefix(x):
return len(set(x)) == 1
starting=""
rules=[]
common=[]
alphabetset=["A'","B'","C'","D'","E'","F'","G'","H'","I'","J'","K'","L'","M'","N'","O'","P'","Q'","R'","S'","T'","U'","V'","W'","X'","Y'","Z'"]
s= "S->iEtS|iEtSeS|a"
while(True):
rules=[]
common=[]
split=s.split("->")
starting=split[0]
for i in split[1].split("|"):
rules.append(i)
#logic for taking commons out
for k, l in groupby(rules).items():
r = [l[0] for l in takewhile(prefix, zip(*l))]
common.append(''.join(r))
#end of taking commons
for i in common:
newalphabet=alphabetset.pop()
print(starting+"->"+i+newalphabet)
index=[]
for k in rules:
if(k.startswith(i)):
index.append(k)
print(newalphabet+"->",end="")
for j in index[:-1]:
stringtoprint=j.replace(i,"", 1)+"|"
if stringtoprint=="|":
print("\u03B5","|",end="")
else:
print(j.replace(i,"", 1)+"|",end="")
stringtoprint=index[-1].replace(i,"", 1)+"|"
if stringtoprint=="|":
print("\u03B5","",end="")
else:
print(index[-1].replace(i,"", 1)+"",end="")
print("")
break