算符优先语法分析设计原理与实现

news2025/2/5 14:51:24

前言:

作者的词法分析程序以及算符优先语法分析设计程序仓库链接

1、目标任务

**[实验项目] **以专题 1 词法分析程序的输出为语法分析的输入,实现算符优先分析算法,完成以下描述算术表达式的算符优先文法的算符优先分析过程。

G[E]:E→E+T∣E-T∣T 
	 T→T*F∣T/F∣F 
	 F→(E)∣i

[设计说明] 终结符号 i 为用户定义的简单变量,即标识符的定义。

**[设计要求] **(1)构造该算符优先文法的优先关系矩阵或优先函数;(2)输入串应是词法分析的输出二元式序列,即某算术表达式“专题 1”的输出结果。输出为输入串是否为该文法定义的算术表达式的判断结果。(3)算符优先分析过程应能发现输入串出错。(4)设计至少四个测试用例(尽可能完备,正确和出错),并给出测试结果;

优先关系矩阵的构造如下图所示:

在这里插入图片描述

程序功能描述:

程序的功能是执行算符优先分析,用于对给定的表达式进行语法分析。它基于算符优先算法来确定表达式中运算符的优先级和结合性,以此进行语法分析。主要步骤包括:

  1. 读取输入表达式: 从名为 “test.txt” 的文件中读取表达式。
  2. 预处理: 将读取的表达式中的变量和常量替换为 ‘i’ 符号,得到用于分析的表达式。
  3. 算符优先级分析: 使用算符优先算法对表达式进行分析。
  4. 分析过程: 逐步检查表达式中的运算符优先级,利用预先定义的优先级矩阵和语法规则来判断是否存在语法错误或可以规约的部分。
  5. 输出结果: 根据分析结果,程序会输出语法分析的结果,指出是否表达式符合定义的语法规则。

主要数据结构描述:

  1. map<char, map<char, char>> priorityMatrix: 这是一个嵌套的 map 结构,用于表示算符之间的优先关系。外部的 char 表示当前栈顶运算符,内部的 map<char, char> 表示当前输入运算符和栈顶运算符的优先级关系。
  2. map<string, char> grammer: 这个 map 结构定义了语法规则,将字符串作为键,将对应的非终结符作为值。它表示了规约过程中可以使用的规则。
  3. vector Vt: 包含终结符号的向量。这里存储了表达式中可能出现的所有终结符号。
  4. vector Vn: 包含非终结符号的向量。这个向量包含了在语法规则中用于推导的非终结符号。
  5. vector s: 这是模拟的分析栈,用于存储算符优先分析过程中的中间状态。

程序结构描述:

函数定义和其功能:

  1. readFile():

    • 从文件 “test.txt” 中读取输入的表达式。
    • 对读取的表达式进行预处理,将变量和常量替换为 ‘i’ 符号。
    • 返回预处理后的表达式字符串。
  2. OperatorPrecedenceAnalysis(string& str):

    • 实现算符优先语法分析的核心逻辑。
    • 接收一个字符串作为输入,对其进行算符优先分析。
    • 利用优先级矩阵和语法规则进行分析,判断是否符合语法规则,返回分析结果(true/false)。
  3. reduce(string& temp):

    • 用于在分析过程中进行规约操作。
    • 根据规约的临时字符串,在语法规则中查找对应的规约字符。
  4. isVt(char ch)isVn(char ch):

    • 判断给定字符是否为终结符和非终结符。
    • 分别用于检查输入字符是否属于终结符和非终结符。
  5. displayAnalysisProcess(const vector& stack, const string& input, int inputPointer):

    • 打印当前分析栈的内容和剩余输入串的内容。
  6. main():

    • 主函数,负责程序的整体流程控制。

    • 调用readFile()读取输入表达式。

    • 调用OperatorPrecedenceAnalysis()执行算符优先语法分析。

    • 根据语法分析的结果输出相应的信息。

函数调用关系:

  • main() 调用 readFile() 获取表达式,然后调用 OperatorPrecedenceAnalysis() 执行语法分析。
  • OperatorPrecedenceAnalysis() 在分析过程中可能调用 reduce() 进行规约操作,并在必要时调用 isVt()isVn() 进行符号类型判断。
  • reduce() 在规约时根据临时字符串查找对应的规约字符。
  • displayAnalysisProcess() 在每次分析时用于输出当前状态。

程序测试:

测试文件:

在这里插入图片描述
在这里插入图片描述

测试文件:

在这里插入图片描述

在这里插入图片描述

测试文件:
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1337039.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PgSQL技术内幕 - ereport ERROR跳转机制

PgSQL技术内幕 - ereport ERROR跳转机制 使用客户端执行SQL的时候经常遇到报ERROR错误&#xff0c;然后SQL语句就退出了。当然&#xff0c;事务也会回滚掉。本文我们看下它是如何做到退出SQL语句并回滚事务的。 1、以insert一个numeric类型值为例 表一个字段为numeric(10,2)类型…

账号与权限管理

一、Linux用户 1.1用户类型 1.普通用户&#xff1a;权限受到限制的用户 2.超级管理员&#xff1a;至高无上的权限 3.程序用户&#xff1a;是给程序使用的&#xff0c;不允许登录(为了安全性考虑) 能不能打开文件和用户有关&#xff0c;用户有自己的权限 运行程序不能使用超…

关于chatglm3 function calling的理解

ChatGLM3-6B开源了工具调用&#xff0c;好奇他是怎么实现的&#xff0c;所以写了这个文章记录。 一、测试官方的示例 官方给的示例很简单&#xff0c;只不过给的两个函数 track 和 text-to-speech 没有具体的实现&#xff0c;模型的输出也只是给出了需要调用的函数名和参数。剩…

w16php系列之基础数组

一、索引数组 概念 索引数组 是指键名为整数的数组。默认情况下&#xff0c;索引数组的键名是从0开始&#xff0c;并依次递增。它主要适用于利用位置&#xff08;0、1、2……&#xff09;来标识数组元素的情况。另外&#xff0c;索引数组的键名也可以自己指定 示例代码 <…

网络调优,部署内网备份冗余和负载分担---实验

目录 网络调优&#xff0c;部署内网备份冗余和负载分担---实验 拓扑 需求 配置步骤&#xff1a; 配置命令: 网络调优&#xff0c;部署内网备份冗余和负载分担---实验 拓扑 需求 主机获取IP地址&#xff0c;访问WEB服务器&#xff0c;WEB服务器网关在SW5上SW5作为VLAN10,V…

【实施】共享目录防火墙

文章目录 一、共享文件1.1 为什么需要配置文件夹共享功能1.2 配置文件夹共享功能1.3 访问共享文件1.4 普通共享和高级共享 二、安装JDK和Tomcat2.1 安装JDK2.2 安装Tomcat 三、防火墙配置 一、共享文件 1.1 为什么需要配置文件夹共享功能 我们在工作和生活中经常有需要将自己…

2024年五个大胆的网络安全预测

纵观历史&#xff0c;网络安全行业不断对攻击者的转变以及运营现实的变化做出反应&#xff0c;新的一年也不例外。随着人工智能和云计算等新技术改变网络安全格局&#xff0c;攻击者和防御者之间的猫捉老鼠游戏肯定会加剧&#xff0c;并且会变得更加复杂。 再加上其他因素&…

带你学C语言~指针(3)

目录 ✍0.前言 &#x1f680;1.字符指针变量 &#x1f685;2.数组指针变量 &#x1f431;‍&#x1f3cd;2.1.数组指针变量是什么 &#x1f431;‍&#x1f3cd;2.2数组指针变量怎么初始化 &#x1f6a2;3.二维数组传参的本质 &#x1f680;4.函数指针变量 ✈4.1函数指…

15个主流设计灵感网站,激发你的创作灵感!

即时设计 即时设计是一种强大的云设计工具&#xff0c;已成为许多设计师、产品经理和开发人员的首选工具之一。即时设计用户可以使用内置的工具和功能快速创建和编辑设计&#xff0c;或与其他用户共享和合作。此外&#xff0c;即时设计还有一个丰富的资源社区&#xff0c;为用…

制造业数字化转型的核心不止是技术

一、制造业的数字化转型意味着什么&#xff1f; 在当今的制造业领域&#xff0c;数字化转型意味着通过集成数字技术来增强传统的制造方法、产品和劳动力的过程。这些技术包括一系列创新&#xff0c;如自动化软件、电子商务系统、传感器、工业机器人等。 二、制造业数字化转型的…

ubuntu 安装apisix -亲测可用

官方未提供在ubuntu系统中安装apisix的方式&#xff0c;似乎只能通过源码方式安装&#xff0c;但是并不推荐&#xff0c;非常容易失败&#xff0c; 具体操作方式如下&#xff1a; ubuntu和Debian其实类似的&#xff0c;可使用DEB方式安装&#xff0c;如下截图 注意&#xff1…

22000mAh 电池,这款国产新机来了场「续航」震撼

见惯了主流智能手机&#xff0c;是时候上一波离谱新机震撼了。 三防手机这一细分类型&#xff0c;咱们普通用户可能接触得比较少&#xff1b; 但对于极限运动、野外探险爱好者来说&#xff0c;这玩意儿可是关键时候能救命的必备神器。 在真正严苛环境面前&#xff0c;性能啥的…

《Vue2.X 进阶知识点》- 防 ElementUI Divider 分割线

前言 使用 el-divider 背景为白色是没问题的。 但当背景换成其它颜色&#xff0c;问题就出现了&#xff01;&#xff01; 仔细看原来是两层&#xff0c;默认背景色是白色。 想着把背景色改为透明应该能用&#xff0c;结果发现背面是一条实线&#xff0c;难怪要用白色遮挡…不符…

使用LLaMA-Factory微调ChatGLM3

1、创建虚拟环境 略 2、部署LLaMA-Factory &#xff08;1&#xff09;下载LLaMA-Factory https://github.com/hiyouga/LLaMA-Factory &#xff08;2&#xff09;安装依赖 pip3 install -r requirements.txt&#xff08;3&#xff09;启动LLaMA-Factory的web页面 CUDA_VI…

HarmonyOS4.0系统性深入开发05ArkTS卡片运行机制

ArkTS卡片运行机制 实现原理 图1 ArkTS卡片实现原理 卡片使用方&#xff1a;显示卡片内容的宿主应用&#xff0c;控制卡片在宿主中展示的位置&#xff0c;当前仅系统应用可以作为卡片使用方。卡片提供方&#xff1a;提供卡片显示内容的应用&#xff0c;控制卡片的显示内容、…

ElasticSearch 聚合统计

聚合统计 度量聚合&#xff1a;求字段的平均值&#xff0c;最小值&#xff0c;最大值&#xff0c;总和等 桶聚合&#xff1a;将文档分成不同的桶&#xff0c;桶的划分可以根据字段的值&#xff0c;范围&#xff0c;日期间隔 管道聚合&#xff1a;在桶聚合的结果上执行进一步计…

【MYSQL】MYSQL 的学习教程(七)之 慢 SQL 优化思路

1. 慢 SQL 优化思路 慢查询日志记录慢 SQLexplain 分析 SQL 的执行计划profile 分析执行耗时Optimizer Trace 分析详情确定问题并采用相应的措施 1. 慢查询日志记录慢 SQL 如何定位慢SQL呢&#xff1f; 我们可以通过 慢查询日志 来查看慢 SQL。 ①&#xff1a;开启慢查询日志…

围栏中心点

后端返回的数据格式是 [{height: 0,lat: 30.864277169098443,lng:114.35252972024682}{height: 1,lat: 30.864277169098443,lng:114.35252972024682}.........]我们要转换成 33.00494857612568,112.53886564762979;33.00307854503083,112.53728973842954;33.00170296814311,11…

labuladong日常刷题-递归魔法 | LeetCode 206反转链表 92反转链表-ii

递归魔法 LeetCode 206 反转链表 2023.12.26 题目链接labuladong讲解[链接] ListNode* reverseList(ListNode* head) {//递归退出条件if(head NULL || head->next NULL)return head;//递归ListNode* last reverseList(head->next);//处理head->next->next …

腾讯云轻量服务器4核8G12M有三年优惠价表

腾讯云轻量服务器4核8G12M有三年优惠价吗&#xff1f;有&#xff0c;但是不怎么优势&#xff0c;相对于云轻量2核2G4M带宽三年价格是540元、2核4G5M带宽3年优惠价756元&#xff0c;4核8G12M轻量应用服务器三年价格是5292元&#xff0c;怎么样&#xff1f;还想买吗&#xff1f;阿…