logo
  • write-homewrite-home-active首页
  • icon-chaticon-chat-activeAI 智能助手
  • icon-pluginicon-plugin-active浏览器插件
  • icon-subjecticon-subject-active学科题目
  • icon-uploadicon-upload-active上传题库
  • icon-appicon-app-active手机APP
首页
/
计算机
题目

给定文法:S∷=a|∧|(T)T∷=T,S|S(1)改写这个文法,消除左递归。(2)改写后的文法是否是LL(1)文法?若是,构造它的LL(1)分析表。(3)写出该文法所描述的语言是什么?

给定文法:S∷=a|∧|(T)T∷=T,S|S(1)改写这个文法,消除左递归。(2)改写后的文法是否是LL(1)文法?若是,构造它的LL(1)分析表。(3)写出该文法所描述的语言是什么?

题目解答

答案

解:(1)改写后的文法为:S∷=a | ∧ | (T)T∷=ST’T’∷=,ST’ | ε(2)①构造FIRST集FIRST(S)= FIRST(T)={ a, ∧, ( }FIRST(T’)={ , , ε }②构造FOLLOW集FOLLOW(S)={ #, , , ) }FOLLOW(T)= FOLLOW(T’)={)}③构造LL(1)分析表FIRST(a)={a}FIRST(∧)={∧}FIRST((T))={(}FIRST(ST’)={ a, ∧, ( }FIRST(,ST’)={, }a∧(),#SS→aS→∧S→(T)TT→ST’T→ST’T→ST’T’T’→εT’→,ST’从分析表可以看出,不存在冲突,所以改写后的文法是LL(1)文法。(3)描述的语言是以a或者~为元组成分的n元组,例如(a, ~, a, ~, a)

解析

考查要点:本题主要考查文法的左递归消除、LL(1)文法的判断及分析表的构造,以及文法语言的描述。

解题核心思路:

  1. 消除左递归:通过改写文法,将直接左递归转换为间接左递归,消除冲突。
  2. 判断LL(1)文法:通过计算FIRST和FOLLOW集合,构造分析表,检查是否存在冲突。
  3. 语言描述:根据文法规则推导生成的符号序列特征。

破题关键点:

  • 左递归消除的关键是将形如A∷=Aα | β的规则改写为A∷=βA',A'∷=αA' | ε。
  • LL(1)判断需确保分析表中每个单元无多重定义。
  • 语言特征需结合文法的递归结构和符号组合方式。

(1) 消除左递归

原文法中,T∷=T,S | S存在直接左递归。改写步骤如下:

  1. 提取公共部分:将T的定义拆分为T∷=ST'。
  2. 处理剩余部分:将原规则T,S中的T替换为ST',得到T'∷=,ST' | ε。

改写后的文法:

S∷=a | ∧ | (T)
T∷=ST'
T'∷=,ST' | ε

(2) 判断LL(1)文法

构造FIRST集

  • FIRST(S):直接推导出的符号为a、∧、(T),故FIRST(S) = {a, ∧, (}。
  • FIRST(T):T = ST',FIRST(T) = FIRST(S) = {a, ∧, (}。
  • FIRST(T'):T'可推导出,ST'或ε,故FIRST(T') = {, , ε}。

构造FOLLOW集

  • FOLLOW(S):S出现在(T)中,且T后可能接), ,或结束符#,故FOLLOW(S) = {#, , ), }。
  • FOLLOW(T):T出现在(T)中,后接),故FOLLOW(T) = {)} }。
  • FOLLOW(T'):T'与T同上下文,故FOLLOW(T') = {)} }。

构造LL(1)分析表

根据FIRST和FOLLOW集,分析表如下:

  • S的产生式:根据输入符号选择对应规则。
  • T和T'的产生式:根据当前符号匹配FIRST集。

结论:分析表无冲突,改写后的文法是LL(1)文法。

(3) 语言描述

文法生成的字符串由a或∧组成,可能嵌套或逗号分隔。例如:(a, ∧, (a, ∨))。

相关问题

  • 下列哪项不是求解对抗搜索问题的基本算法( ) A.反向传播算法 B.广度优先排序算法 C.Alpha-Beta剪枝算法D.最小最大搜索算法

  • 在决策树建立过程中,使用一个属性对某个结点对应的数集合进行划分后,结果具有高信息熵(highentropy),对结果的描述,最贴切的是()。A. 纯度高B. 纯度低C. 有用D. 无用E. 以上描述都不贴切

  • 程序=算法+()A. 数据结构B. 程序结构C. 控制结构[1]D. 体系结构

  • 网络安全包括物理安全[1]、逻辑安全、操作系统安全及联网安全,其中逻辑安全包括访问控制[2]、加密、安全管理及用户身份认证。A. 正确B. 错误

  • 路径排序算法的工作流程主要有三步()A. 特征计算B. 特征抽取C. 分类器训练D. 因果推断

  • 下列哪项贪婪最佳优先搜索算法的描述正确()A. 贪婪最佳优先搜索不属于启发式搜索算法B. 贪婪最佳优先搜索是一种A*搜索算法C. 贪婪最佳优先搜索是一种广度优先搜索算法D. 贪婪最佳优先搜索属于有信息搜索算法

  • 下列哪个方法属于知识图谱推理方法()A. 路径排序算法B. 深度学习推断C. 广度优先搜索D. 归纳逻辑程序设计

  • 网络诈骗中常见的“钓鱼网站”目的是()?A. 传播病毒B. 窃取个人信息C. 提供免费电影

  • 7、 加强电脑安全防护,及时升级病 毒库,安装防火墙,及时查杀病毒和木马,是防范 电信网络诈骗的有效做法。A. 正确B. 错误

  • AdaBoosting采用多个单一分类器组成一个强分类器()A. 错误B. 正确

  • 2.单选题 讯飞星火可以实现多种文案类型和语言风格的文本写作。讯飞星火(网页版)“内容写作”功能可选的“语言风格”不包括( )。A. 口语化B. 高情商C. 专业D. 热情

  • 下列哪项属于因果推理模型()A. 因果图B. 神经符号推理C. 符号推理模型D. 结构因果模型

  • 3.判断题K-means聚类算法对数据的尺寸敏感。()A. 对B. 错

  • 以下哪种方法属于卷积神经网络的基本组件()。A. 卷积层B. 池化层C. 激活函数D. 复制层

  • Windows中“复制”操作的快捷键是Ctrl+V。

  • 下列哪项关于监督学习算法的描述正确()A. 强化学习的训练效果一定优于监督学习B. 主要的监督学习方法包括生成方法和判别方法C. 广度优先搜索算法是一种监督学习算法

  • 网络安全包括物理安全[1]、逻辑安全、操作系统安全及联网安全,其中逻辑安全包括访问控制[2]、加密、安全管理及用户身份认证。A. 正确B. 错误

  • 下列不属于量子机器学习算法的是()A. 量子支持向量机B. 量子主成分分析C. 薛定谔方程求解D. 深度量子学习

  • 由脸书(Facebook)公司开发的深度学习编程框架是()A. TensorFlowB. PaddlePaddleC. PyTorchD. Mindspore

  • 下列哪个方法属于知识图谱推理方法()A. 广度优先搜索B. 深度学习推断C. 路径排序算法D. 归纳逻辑程序设计

上一页下一页
logo
广州极目未来文化科技有限公司
注册地址:广州市黄埔区揽月路8号135、136、137、138房
关于
  • 隐私政策
  • 服务协议
  • 权限详情
学科
  • 医学
  • 政治学
  • 管理
  • 计算机
  • 教育
  • 数学
联系我们
  • 客服电话: 010-82893100
  • 公司邮箱: daxuesoutijiang@163.com
  • qt

©2023 广州极目未来文化科技有限公司 粤ICP备2023029972号    粤公网安备44011202002296号