B04
This commit is contained in:
parent
3dbd3a09d5
commit
386edf797c
10
TaskB04/fsa_description.arg
Normal file
10
TaskB04/fsa_description.arg
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
0 1 0
|
||||||
|
0 3 1
|
||||||
|
1 0 0
|
||||||
|
1 2 1
|
||||||
|
2 3 0
|
||||||
|
2 1 1
|
||||||
|
3 2 0
|
||||||
|
3 0 1
|
||||||
|
1
|
||||||
|
2
|
43
TaskB04/run.py
Normal file
43
TaskB04/run.py
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import sys
|
||||||
|
|
||||||
|
# fsa_description = sys.argv[1]
|
||||||
|
# inputWords = sys.argv[2]
|
||||||
|
# outputResult = sys.argv[3]
|
||||||
|
|
||||||
|
fsa_description = "fsa_description.arg"
|
||||||
|
inputWords = "test.in"
|
||||||
|
outputResult = "test.out"
|
||||||
|
|
||||||
|
|
||||||
|
def readDescription(currentPos, charInput):
|
||||||
|
with open(fsa_description, 'r', encoding="utf-8") as descript:
|
||||||
|
for line in descript:
|
||||||
|
if len(line.strip().split(' ')) == 1:
|
||||||
|
return line[0], 0
|
||||||
|
transition = line.strip().split(' ')
|
||||||
|
if len(transition) == 3 and currentPos == transition[0] and charInput == transition[2]:
|
||||||
|
return transition[1], 1
|
||||||
|
return None, None
|
||||||
|
|
||||||
|
answersYN = ''
|
||||||
|
with open(inputWords, 'r', encoding="utf-8") as inputString:
|
||||||
|
for line in inputString:
|
||||||
|
pos = '0'
|
||||||
|
for char in line:
|
||||||
|
if char == '\n':
|
||||||
|
answersYN += ('1' if pos == '1' or pos == '2' else '0')
|
||||||
|
break
|
||||||
|
newPos, flag = readDescription(pos, char)
|
||||||
|
if flag == 1:
|
||||||
|
pos = newPos
|
||||||
|
|
||||||
|
with open(outputResult, 'w', encoding="utf-8") as output:
|
||||||
|
for i in range(0, len(answersYN)):
|
||||||
|
if answersYN[i] == '1':
|
||||||
|
# print("YES")
|
||||||
|
output.write("YES\n")
|
||||||
|
elif answersYN[i] == '0':
|
||||||
|
# print("NO")
|
||||||
|
output.write("NO\n")
|
||||||
|
|
||||||
|
print(answersYN)
|
14
TaskB04/test.out
Normal file
14
TaskB04/test.out
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
YES
|
||||||
|
YES
|
||||||
|
NO
|
||||||
|
NO
|
||||||
|
NO
|
||||||
|
YES
|
||||||
|
NO
|
||||||
|
YES
|
||||||
|
NO
|
||||||
|
YES
|
||||||
|
NO
|
||||||
|
NO
|
||||||
|
YES
|
||||||
|
NO
|
Loading…
Reference in New Issue
Block a user