news 2026/4/30 12:09:31

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

作者头像

张小明

前端开发工程师

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/5/1 2:45:07

嵌入式知识---555定时器

1. 一句话概括它是什么555定时器是一个“可以用电阻和电容来定制时间的模拟-数字混合芯片”。 它就像一个 “可编程的定时开关” 或 “电子心脏”,能产生精确的延时、脉冲或连续的振荡信号。简单比喻:它是一台 “电子秒表” 和 “电子节拍器” 的结合体。…

作者头像 李华
网站建设 2026/5/1 2:42:22

嵌入式知识篇---再看74LS192

1. 一句话建立印象74LS192 是一个“能加能减、能设起点的电子计数器”。 它就像你手表上的计时器功能:可以正着走(从0累加),也可以倒计时(从设定值递减),还可以随时重置到任意时间。2. 核心功能…

作者头像 李华
网站建设 2026/5/1 2:45:38

江湖四门:邪术门派的绝密智慧

江湖四门:邪术门派的绝密智慧 一、四门概览:下九流的生存之道 江湖四门(又称"邪术门派")是中国古代底层社会发展出的生存智慧体系,与主流"上九流"(儒释道等)相对,被称为"下三滥的旁门走道"。 四大门派核心定位: 门派 核心技能 代表人…

作者头像 李华
网站建设 2026/5/1 3:43:52

YOLOv11模型训练实战:基于PyTorch-CUDA环境全流程

YOLO模型训练实战:基于PyTorch-CUDA环境的全流程实践 在智能安防摄像头需要实时识别行人、车辆和异常行为的今天,一个关键问题摆在开发者面前:如何在保证检测精度的同时,将训练周期从几天压缩到几小时?这个问题背后&am…

作者头像 李华
网站建设 2026/5/1 4:46:13

PyTorch-CUDA镜像内置常用库列表,省去手动安装烦恼

PyTorch-CUDA 镜像:开箱即用的深度学习环境,告别“环境地狱” 在深度学习项目中,你是否经历过这样的场景? 刚克隆完同事的代码,满怀期待地运行 pip install -r requirements.txt,结果一连串的 ImportError…

作者头像 李华