码迷,mamicode.com
首页 > 其他好文 > 详细

编译原理课程作业2

时间:2016-04-04 22:48:10      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:

NFA匹配字符串,突然意识到可以用多层的list,然后整个作业就没有难度了,递归部分一直错我都怀疑人生了,结果发现是类里的递归声明要加类名。。

# -*- coding: utf-8 -*-
import sys
class io():
    """read the NFA from file"""
    def __init__(self,strlist):
        self.strlist = strlist
    def i(self):
        if(len(sys.argv)!=3):
            print "there are some errors"
            exit(0)
        file_name = sys.argv[1]
        self.strlist = list(sys.argv[2])
        file = open(file_name)
        """ M = (K ,E ,f ,S0 ,Z  ) """
        self.K = file.readline().strip().split( )
        self.E = file.readline().strip().split( )
        self.f = []
        for i in range(len(self.K)):
            listks = file.readline().strip().split( )
            listks2 = []
            for listk in listks:
                listks2.append(listk.strip().split(,))
            self.f.append(listks2)
        self.S0 = file.readline().strip().split( )
        self.Z = file.readline().strip().split( )
        #print self.K ,self.E ,self.f ,self.S0 ,self.Z,self.strlist
        if (not(set(self.strlist)<=set(self.E))):
            print "no"
            sys.exit()

    def nfa2str(self,numstr = 0,state = s0):
        if(numstr==len(self.strlist) and (state in self.Z)):
            print "yes"
            sys.exit()
        elif(numstr<len(self.strlist)):
            statex = self.K.index(state)
            statey = self.E.index(self.strlist[numstr])
            statesNow = self.f[statex][statey]
            if(statesNow!=[N/A]):
                for stateNow in statesNow:
                    x = io.nfa2str(self,numstr+1,stateNow)

str = []
m = io(str)
m.i()
m.nfa2str()
print "no"

读入的文件nfa.txt

s0 s1
a b
s0,s1 s1
N/A s0,s1
s0
s1

 

编译原理课程作业2

标签:

原文地址:http://www.cnblogs.com/dystopia/p/5352977.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!