news 2026/6/10 18:12:37

文法定义了一个典型的表达式文法,支持加法和乘法,具有左递归以实现左结合

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
文法定义了一个典型的表达式文法,支持加法和乘法,具有左递归以实现左结合

给定文法 $ P = { E \to E + T \mid T, \quad T \to T * F \mid F, \quad F \to (E) \mid \text{id} } $,我们以句子 $ \text{id}_1 + \text{id}_2 * \text{id}_3 $ 为例,进行最右推导、语法树构建和短语分析。


1. 最右推导过程

最右推导(规范推导)是指在每一步推导中,总是替换最右侧的非终结符。从开始符号 $ E $ 出发:

E⇒E+T(使用 E→E+T)⇒E+T∗F(使用 T→T∗F)⇒E+T∗id3(使用 F→id)⇒E+F∗id3(使用 T→F)⇒E+id2∗id3(使用 F→id)⇒T+id2∗id3(使用 E→T)⇒F+id2∗id3(使用 T→F)⇒id1+id2∗id3(使用 F→id) \begin{align*} E & \Rightarrow E + T \quad \text{(使用 } E \to E + T\text{)} \\ & \Rightarrow E + T * F \quad \text{(使用 } T \to T * F\text{)} \\ & \Rightarrow E + T * \text{id}_3 \quad \text{(使用 } F \to \text{id}\text{)} \\ & \Rightarrow E + F * \text{id}_3 \quad \text{(使用 } T \to F\text{)} \\ & \Rightarrow E + \text{id}_2 * \text{id}_3 \quad \text{(使用 } F \to \text{id}\text{)} \\ & \Rightarrow T + \text{id}_2 * \text{id}_3 \quad \text{(使用 } E \to T\text{)} \\ & \Rightarrow F + \text{id}_2 * \text{id}_3 \quad \text{(使用 } T \to F\text{)} \\ & \Rightarrow \text{id}_1 + \text{id}_2 * \text{id}_3 \quad \text{(使用 } F \to \text{id}\text{)} \end{align*}EE+T(使用EE+T)E+TF(使用TTF)E+Tid3(使用Fid)E+Fid3(使用TF)E+id2id3(使用Fid)T+id2id3(使用ET)F+id2id3(使用TF)id1+id2id3(使用Fid)

✅ 最终得到句子:$ \text{id}_1 + \text{id}_2 * \text{id}_3 $

注意:这是最右推导,因此每次都优先展开最右边的非终结符(如先处理 $ T $ 中的 $ F $,再往左处理 $ E $)。


2. 推导的树结构(语法树)

E / | \ E + T /| \ / | \ T F T * F /|\ \ /|\ \ F id2 id3 | id1

更清晰地表示为:

E / | \ E + T | / \ T T * | | | F F id3 | | id1 id2

但实际上,根据推导顺序,应为:

E / | \ E + T | / \ T T * | | | F F F | | | id1 id2 id3

但注意:由于 $ T \to T * F $,所以中间的 $ T $ 应该是递归生成的。正确语法树如下:

E / | \ E + T /|\ /|\ T T * F | | | F F id3 | | id1 id2

而最底层的 $ T \to F \to \text{id}_2 $,所以完整结构是左递归展开。

最终语法树反映了左结合的+*,且*优先级高于+


3. 短语分析

基于上述最右推导过程,识别短语与直接短语:

  • 短语:在一个句型中,能被某个非终结符逐步推导出的子串称为该非终结符的短语。
  • 直接短语(素短语):仅通过一步推导就能得到的短语(即使用一次产生式替换)。

分析句型 $ \text{id}_1 + \text{id}_2 * \text{id}_3 $ 的各部分:

子串对应非终结符是否为短语是否为直接短语理由
$ \text{id}_1 $$ F $$ F \Rightarrow \text{id}_1 $
$ \text{id}_2 $$ F $$ F \Rightarrow \text{id}_2 $
$ \text{id}_3 $$ F $$ F \Rightarrow \text{id}_3 $
$ \text{id}_2 * \text{id}_3 $$ T $$ T \Rightarrow T * F \Rightarrow^* \text{id}_2 * \text{id}_3 $
$ \text{id}_1 + \text{id}_2 * \text{id}_3 $$ E $整个句子由 $ E $ 推导而来

此外:

  • $ \text{id}_1 $ 是相对于 $ T $ 的短语吗?→ 是,因为 $ T \Rightarrow F \Rightarrow \text{id}_1 $
  • 直接短语只有那些一步推出的:$ \text{id}_1, \text{id}_2, \text{id}_3 $
  • 句柄(handle)是最左直接短语,在最右推导中用于规约的关键部分,此处为 $ \text{id}_3 $(首次规约对象)

总结

  • 文法定义了一个典型的表达式文法,支持加法和乘法,具有左递归以实现左结合。
  • 最右推导展示了如何从 $ E $ 一步步生成目标句子,强调了运算符优先级(*高于+)。
  • 语法树直观体现结构:+的右操作数是一个T(即id2 * id3),说明*先结合。
  • 短语分析有助于理解语义计算和语法分析器设计(如 LR 分析器中的规约动作)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 11:43:48

GitHub Star 数量前 12 的 AI 工作流项目

原文链接:https://www.nocobase.com/cn/blog/top-12-ai-workflows-projects-with-the-most-github-stars 提到工作流和自动化,无论是开源的 n8n 、Dify,还是一些较为知名的商业化产品,例如 Zapier、Make,你可能都不陌…

作者头像 李华
网站建设 2026/6/10 3:59:44

深度学习环境搭建太复杂?试试我们的一键启动镜像

深度学习环境搭建太复杂?试试我们的一键启动镜像 在深度学习项目中,你是否经历过这样的场景:刚克隆完一个开源模型仓库,满心期待地运行 python train.py,结果却弹出一连串错误——CUDA 版本不匹配、cuDNN 未安装、PyT…

作者头像 李华
网站建设 2026/6/10 11:38:24

TikTokitem_search_video关键词视频列表接口对接全攻略:从入门到精通

TikTok 的item_search_video接口是按关键词批量检索平台视频列表的核心工具,支持按地区、发布时间、互动量、内容类型、带货属性等多维度筛选,返回视频基础信息、互动数据、创作者信息、商品标签等关键内容,适配跨境内容聚合、爆款视频挖掘、…

作者头像 李华
网站建设 2026/6/10 9:06:27

计算机Java毕设实战-基基于SpringBoot+Vue的高校学习讲座预约管理系统设计于SpringBoot的高校学习讲座预约系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华