Python实现LR分析

本文探讨了如何使用Python实现LR分析,输入包括输入序列w和文法G的LR分析表action和goto。通过初始格局(#0, w#, 驱动器的第一个动作)开始,逐步进行规范规约,解析过程涉及栈操作,直至完成w的分析或找出错误。" 16805529,1471643,CentOS 6.4 LVS 安装教程:RPM与源码方法,"['服务器', 'yum', '源码', 'centos6.4']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

算法:LR分析
输入:输入序列w和文法G的LR分析表action和goto
输出:若w属于L(G),得到w的规范规约,否则指出一个错误
方法:初始格局为(#0, w#, 驱动器的第一个动作),其中0是初始状态。令ip指向w#中的第一个终结符,top指向栈顶初始状态

import copy

#输入输入序列w 和预测分析表M ,非终结符的集合N ,开始进行预测分析
def LR_analyze(w, LR ,P):
    mat = "步骤{:<15}\t栈内容 {:<20}\t当前输入 {:<25}\t动作{:<30}"
    print(mat.format(" "," "," "," ",))
    Stack = list()  # 创建符号栈
    Stack.append('#')#压入结束表示符#
    Stack.append('0')#压入状态0
    top = len(Stack)-1 #top用于记录栈顶的下标,即最后一个元素下标
    ip = 0#用于记录输入序列w中的终结符的下标,从首部开始
    step = 1 #记录步骤
    # 当栈非空
    while Stack:
        content = ''.join(Stack)#将栈内容转为字符串
        inputchar = ''.join(w[ip:])
        action = ""
        accept = False #表示是否成功返回
        a = w
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值