编译原理及应用期末复习

news2024/11/25 8:35:31

3型文法 = 右线性文法

短语、直接短语、句柄

在这里插入图片描述

、判断是否是二义性文法

1、证明是二义性文法:证明存在一个句子有两颗不同的语法树

① 画语法分析树

在这里插入图片描述

、NFA、DFA

K:所有状态,包含初始状态
Σ:终结字符集
M:状态转换表达式
S:开始符号
F:结束符号(可以有多个)
在这里插入图片描述

最小化

  • 如果给的是一张表,那就先化简,删去那些根本到不了的状态
  • 最小化的结果就是画出状态转换图
    在这里插入图片描述

消除左递归性

在这里插入图片描述

First 集

First 集:首符号集
就是找最左边可能出现的终结符

例子:
在这里插入图片描述

分三种情况
在这里插入图片描述

Follow集

先找到待求的大写字母(只从所有产生式的右部找),然后看他的右边,判断右边属于哪种情况
在这里插入图片描述

LR(0)文法

任意一个项目集中都不能出现以下两种情况:

  • 同时出现移进项(点后面是终结符)和归约项(点后面没有东西)
  • 同时存在两个及以上归约项
    否则他就是LR(0)文法

在这里插入图片描述

1、状态分析表

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

2、LR 分析表

ACTION表(移进项、接受项、归约项)

表头写出所有的终结符
移进项写S几,几是项的序号
接受项写acc
项集是归约项,写r几,几是产生式的序号

GOTO 表(只写待约项的)

表头写出所有的非终结符
待约项直接写数字
在这里插入图片描述

LR(0) 分析过程(SLR分析过程类似)

在这里插入图片描述
在这里插入图片描述
翻译:
对于每一行,都先去分析表中找 第 状态栈栈顶 行,符号栈栈顶 列,看他是啥:

  • 若是移进项,找到S几,脚标放状态栈
  • 若是归约项,找到对应序号的产生式:r几 写到 ACTION 列,出栈右部长度个元素,写出GOTO[状态栈的栈顶,左部],去分析表中寻找第 状态栈栈顶 行,第 左部 列的数字写到GOTO列,同时该数字作为新的状态栈栈顶;而左部作为新的符号栈栈顶

对于发生冲突的项,选择能够继续往下分析的项。(SLR分析)
在这里插入图片描述

SLR(1) 分析表

对发生冲突的移进项和归约项求简单向前看1集合

  • 对于移进项,就是点后面的 终结符
  • 对于归约项,就是 Follow(左部)

在这里插入图片描述

在 LR(0) 分析表的基础上,
对于每个归约项,求他的 Follow集,只在出现在 follow 集中的输入符号处写 r几
其他和LR(0)一样
在这里插入图片描述

SLR 分析的过程和SL一样

错题

选择

在这里插入图片描述

在这里插入图片描述
记法:语言由句子构成

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

判断

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

填空

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

大题

画分析树

本体关键:如何不重不漏
画圈法:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

递归文法

主要看答题模板:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

有限自动机

主要看答题模板:
在这里插入图片描述
在这里插入图片描述

语法制导

判断继承属性 和 综合属性

看后面打括号里面的每个式子,式子左边的部分在产生式的左部就是综合属性,在产生式的右部就是继承属性

注释分析树:

属的躯干其实就是语法分析树
还要加上每个结点的值以及箭头指向

例题:

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

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

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

相关文章

chatgpt赋能python:Python中替换字符串成int类型的方法

Python中替换字符串成int类型的方法 简介 在Python编程过程中,经常需要对字符串进行处理。有时候我们需要将字符串中的某些字符替换成int型数据,以便于进行一定的数值计算或其他操作。本文将介绍如何在Python中找出需要替换的字符,并将其转…

Python实现将txt文件转换成对应的excel或csv文件

前言 本文是该专栏的第29篇,后面会持续分享python的各种干货知识,值得关注。 工作上可能会遇到这样的情况,使用python将某个txt文本,按照行索引和列索引转换成对应的excel文件或者是csv文件。 那对于这样的需求,用python如何实现呢?跟着笔者直接往下看解决方法。(附完…

UART协议总结

UART( Universal Asynchronous Receiver-Transmitter,通用异步收发器),是异步串行通信协议,用来传输串行数据。 1、UART原理说明 UART是全双工工作模式,其数据传输方法如下: 发送数据时&…

Hive 和 Oracle 中 Decode 函数的用法差异

前言 在数仓构建过程中,需要从业务那边进行数据的迁移!数仓大多数公司都是使用Hive,而业务那边使用的是Oracle数据库居多。最近就有个小伙伴在迁移的时候碰到了问题: 从报错来看,在使用 Decode() 函数的时候,传参有问题! 既然问题来了,我们就来解决一下呗,只有不断地…

基础知识学习---牛客网C++面试宝典(五)操作系统--第一节

1、本栏用来记录社招找工作过程中的内容,包括基础知识学习以及面试问题的记录等,以便于后续个人回顾学习; 暂时只有2023年3月份,第一次社招找工作的过程; 2、个人经历: 研究生期间课题是SLAM在无人机上的应…

LeetCode_Day6 | 四数相加||、赎金信、三数之和、四数之和!

LeetCode_哈希表 454.四数相加1.题目描述2.思路3.代码实现 383.赎金信1.题目描述2.暴力法3.哈希法思路代码实现 15.三数之和1.题目描述 454.四数相加 1.题目描述 详情leetcode链接 2.思路 解题步骤: 首先定义 map,key放a和b两数之和,valu…

神器CLIP:连接文本和图像,打造可迁移的视觉模型

2021年见证了vision transformer的大爆发,随着谷歌提出ViT之后,一大批的vision transformer的工作席卷计算机视觉任务。除了vision transformer,另外一个对计算机视觉影响比较大的工作就是Open AI在2021年1月份发布的DALL-E和CLIP&#xff0c…

chatgpt赋能python:一、Python在数据可视化中的应用

一、Python在数据可视化中的应用 Python是一种功能强大的编程语言,早已成为数据科学家和分析师的首选语言。数据可视化对于从数据中汲取信息和传达想法来说至关重要。Python也是数据可视化的理想工具之一。Python提供了许多强大的库,其中包括了一些流行…

( 2023版)互联网 Java 工程师面试题及答案汇总

最近很多粉丝朋友私信我说:熬过了去年的寒冬却没熬过现在的内卷;打开 Boss 直拒一排已读不回,回的基本都是外包,薪资还给的不高,对技术水平要求也远超从前;感觉 Java 一个初中级岗位有上千人同时竞争&#…

【野指针】

野指针 1. 指针是什么?2. 指针和指针类型2.1 指针-整数2.2 指针的解引用 3. 野指针3.1 野指针成因3.2 如何规避野指针 1. 指针是什么? 指针是什么? 指针理解的2个要点: 指针是内存中一个最小单元的编号,也就是地址平…

MySQL性能优化:慢查询优化

一、执行计划 执行计划的语法 在SQL查询的前面加上EXPLAIN关键字就行。比如: EXPLAIN select* from order_exp;执行效果如下。 (一)参数详解: 1、id 在一个大的查询语句中每个SELECT关键字都对应一个唯一的id。我们知道我们写的查询语句一…

【框架源码】Spring源码解析之BeanDefinition加载流程解析

观看本文之前,我们先思考一个问题,Spring是如何描述Bean对象的? Spring是根据BeanDefinition来创建Bean对象,BeanDefinition就是Spring中表示Bean定义。BeanDefinition用来存储Bean的相关信息,主要包括:Be…

【Linux问题】删除用户时错把rm当成userdel删除后,该如何解决彻底删除?

问题引入:之前创建的用户默认在home目录中,过了段时间以为是一个目录就直接使用rm删除了,结果在创建一个和之前用户同名的用户时发现报错:useradd: user ‘cjs’ already exists(该用户已存在)。 1、问题 …

chatgpt赋能python:Python怎么找出最大数的位置?

Python怎么找出最大数的位置? Python是一种高级编程语言,它的简单易学和适用范围广泛使其成为了很多开发者的首选语言。在Python中,有许多方便的内置函数可以帮助我们轻松地处理各种任务。其中之一是查找最大值,但是我们如何找出…

【Linux后端服务器开发】shell脚本

目录 一、变量 1. 普通变量 2. 环境变量 3. 位置变量 4. 特殊变量 二、输入输出 1. read命令接收输入 2. echo命令输出字符串 三、表达式 1. 算术表达式 2. 逻辑表达式 四、分支控制 1. if 分支 2. case 分支 五、循环控制 1. for 循环 2. while 循环 3. unt…

redis键值对映射关系存储-Dict

基本概述 Redis是一个键值型(Key-Value Pair)的数据库,可以根据键实现快速的增删改查。而键与值的映射关系正是通过Dict来实现的。 Dict由三部分组成,分别是:哈希表(DictHashTable)、哈希节点&a…

基于51单片机设计的电动车控制器

一、项目介绍 随着社会经济的快速发展,人们对节能环保的要求越来越高,电动车因其无污染、噪音小、使用成本低等优点逐渐成为了市场关注的焦点。同时,随着科技的不断进步和应用,电动车的技术水平也在不断提高。 为了更好地满足市场需求和科技进步的要求,本项目基于51单片…

车载以太网 - 数据链路层 - VLAN

数据链路层通信 以太网二层数据链路层的寻址方式、帧结构、及 VLAN (Virtual LocalArea Network),其分为LLC(Logical Link Control)逻辑链路控制子层,和 MAC(Media Access Control)媒体访问控制子层,其中,MAC 子层负责以太网的总…

chatgpt赋能python:Python中的异常处理

Python中的异常处理 在Python编程中,异常是指程序出现了不正常的情况,比如语法错误、运行时错误等等。这些异常会导致程序崩溃,所以我们需要在程序中使用异常处理来避免这种情况的发生。 什么是异常处理? 异常处理是一种技术&a…

chatgpt赋能python:Python如何把多行合并成一行

Python如何把多行合并成一行 如果你常常需要处理文本数据,你就会遇到将多行文本合并成一行的需求。在Python中,这个任务非常简单,本文将介绍如何使用Python实现把多行合并成一行。 什么是多行文本? 在编程和文本处理中&#xf…