-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdepo.py
84 lines (76 loc) · 2.5 KB
/
depo.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/bin/python
from util import *
# config:
# type 1: list of letters (numbers)
# type 2: period length, n, p
# type 3: print all possible period lengths
print_type = 3
# use global variable to store all the sequences found upto now
#
# The list contains pairs (a, ap) where A is the period of the sequence
# and AP is sequence where each letter is replaced by the length of its period.
#
sequences_list = []
period_sizes = set()
# check_and_normalize
#
# if incorrect, return None
#
def check_and_normalize(prefix, first, period):
assert len(first) == len(period)
assert all([p > 0 for p in period])
# compute the length of the whole period
per = nsn(period)
a = [-1] * per
ap = [0] * per
for i in range(len(first)):
j = first[i]
while j < per:
# check for conflict - incorrect specification:
if a[j] != -1:
return None
a[j] = i
ap[j] = period[i]
j += period[i]
# check the specification - are all positions filled?
if any([c == -1 for c in a]):
return None
# Oll Korrect
return (a, ap)
# check that the sequence is new
# if yes, add it to the list of knows sequenes (and print it)
def store_seq(prefix, first, period, print_duplicates):
global sequences_list
ret = check_and_normalize(prefix, first, period)
if ret is None:
return
a, ap = ret
# check if the sequence is already known
for dup_id, ap1 in enumerate(sequences_list):
if are_equal(ap, ap1):
if print_duplicates:
print_n_p(first, period, "DUP of {}".format(dup_id))
return
# A new one!
seq_id = len(sequences_list)
sequences_list.append( ap )
period_sizes.add( len(ap) )
if print_type == 1:
print('SEQ: ' + str(a) + '*')
elif print_type == 2:
print_n_p(first, period, seq_id)
def print_n_p(first, period, seq_id):
print("seq {}, with period length {}".format(seq_id, nsn(period)))
print(" n: " + format_num(first))
print(" p: " + format_num(period))
def format_num(seq):
txt = ["{:2d}".format(i) for i in seq]
return " ".join(txt)
def print_summary(num_letters):
if print_type == 3:
print("Possible period lengths for alphabet size {}:".format(num_letters))
period_sizes_list = list(period_sizes)
period_sizes_list.sort()
print(" " + str(period_sizes_list))
else:
print("\nFor alphabet size {}, we found {} words.".format(num_letters, len(sequences_list)))