资源简介
python3.7实现正则表达式到dfa的转变,提供控制台输出文件,graphviz图像输出文件,graphviz图像输出需自行配置相关环境
代码片段和文件信息
from graphviz import Digraph
stack = [] # 储存nfa的栈
flag = [] # 判断图是否遍历完全
symbol = (‘|‘ ‘·‘ ‘*‘ ‘(‘ ‘)‘) # 符号元组
temp = [] # 求闭包时判断是否遍历重复结点
_name = 0 # 求当前结点的数字编号
class State(object): # nfa的起始和终止状态
“““docstring for State“““
def __init__(self start end):
self.start = start
self.end = end
class nfa(): # nfa的每个状态信息
“““docstring for retonfa“““
def __init__(self):
self.name = -1
self.next = []
self.val = []
def Clear(): # 清空flag标志列表
flag.clear()
def initnfa(val): # 初始化一个nfa
global _name
start = nfa()
start.name = _name
_name = _name + 1
end = nfa()
end.name = _name
_name = _name + 1
start.next.append(end)
start.val.append(val)
stack.append(State(start end))
# for i in range(len(start.next)):
# print(start.name start.val[i] start.next[i].name)
# print(start.name end.name)
def stnfa(op): # 构造nfa
global _name
if op == ‘|‘:
start = nfa()
start.name = _name
_name = _name + 1
end = nfa()
end.name = _name
_name = _name + 1
start.next.append(stack[-2].start)
start.val.append(“null“)
start.next.append(stack[-1].start)
start.val.append(“null“)
stack[-2].end.next.append(end)
stack[-2].end.val.append(“null“)
stack[-1].end.next.append(end)
stack[-1].end.val.append(“null“)
stack.pop()
stack.pop()
stack.append(State(start end))
# printnfa(start)
# print(“\n“)
flag.clear()
# for i in range(len(start.next)):
# print(start.name start.val[i] start.next[i].name)
elif op == ‘*‘:
start = nfa()
start.name = _name
_name = _name + 1
end = nfa()
end.name = _name
_name = _name + 1
start.next.append(stack[-1].start)
start.val.append(“null“)
stack[-1].end.next.append(stack[-1].start)
stack[-1].end.val.append(“null“)
stack[-1].end.next.append(end)
stack[-1].end.val.append(“null“)
start.next.append(end)
start.val.append(“null“)
stack.pop()
stack.append(State(start end))
# printnfa(start)
# print(“\n“)
flag.clear()
# for i in range(len(start.next)):
# print(start.name start.val[i] start.next[i].name)
elif op == ‘·‘:
start = nfa()
start.name = _name
_name = _name + 1
end = nfa()
end.name = _name
_name = _name + 1
start.next.append(stack[-2].start)
start.val.append(“null“)
stack[-2].end.next.append(stack[-1].start)
stack[-2].end.val.append(“null“)
stack[-1].end.next.append(end)
stack[-1].end.val.append(“null“)
stack.pop()
stack.pop()
stack.append(State(
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 12119 2018-10-27 11:04 re-dfa.py
文件 171 2018-10-27 11:48 readme.txt
文件 15568 2018-10-27 11:44 retodfa.py
相关资源
- 传智播客python最新视频.txt
- Python升级3.6强力Django杀手级Xadmin打造
- Python实现PCA
- KMeans python 代码
- Python淘宝评论爬取
- py新浪微博爬虫通过修改最后的uid值即
- python基础教程第三版源代码
- PCV---python工具包.zip
- 去停用词、测试数据
- 高效爬取微博数据python3实现
- 基于vggnet卷积神经网络的图像风格迁
- pyton 实现学生信息管理系统
- 数字图像处理Python制作简易软件系统
- Python爬取b站视频弹幕并可视化案例
- python实现类似于QQ或MSN的聊天系统
- sm4国密算法python实现
- python面试题100道
- python_docx-0.8.10-py2.py3-none-any.whl
- python3.4中文学习手册chm
- python 2.7中文手册chm版
- 产生式系统包含动物识别规则库,手
- 数据挖掘教学视频实战超详细加pyth
- python实现KNN手写字体识别Demo
- python q-learning
- python3网络爬虫与开发实战崔庆才PDF百
- python语言实现通过树莓派Pi camera的图
- 扫雷 python
- python习题
- ngramScore适应度计算文件(包含引入的
- 爱鲜蜂项目源码
评论
共有 条评论