SEU编译原理复习(期末考试用)——知识点+习题练习

2024-01-14 10:28

本文主要是介绍SEU编译原理复习(期末考试用)——知识点+习题练习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里给大家推荐下另一位博主的文章,我第一遍是看着这篇文章+课本+老师的复习PPT一起过的,二遍是做的作业题和老师发的往年卷:编译原理 乱七八糟的期末复习笔记_东南大学编译原理期末复习-CSDN博客

一、语言和文法(10分)

1.文法生成语言

请写出对应的语言。

请写出对应的语言。

2.构造无Σ产生的上下文无关文法

(满足的条件:若存在S->Σ,则S不能出现在任何产生式的右侧)

请将该文法改为无Σ产生的上下文无关文法。

3.根据语言写出无Σ文法

这一块稍微有点难度,不过做多了发现也就那样,套路都一样

例一

例二

例三

例四

例五(这个应该是最经典的,要用到DFA)

请构造无Σ的上下文无关文法。

4.判断二义性,消除二义性

emm,这种题的话,一般产生式都是因为没有给出符号优先级而导致的。

例题:

判断该文法是否是二义性文法?给出你的证明。如果是二义性,重写为非二义性文法

二、词法分析(15分)

如果说第一章还有点创新性的东西的话,第二章往后就全部是套做题步骤了。

RA->NFA->minDFA->Context free Grammer(上下文无关文法)

例题1:

还有一个比较难的。所谓难,只不过可能繁琐一点,而不是思路上的难。

例题2:

三、语法分析(25分)

1.Top-down(LL(1)文法)(15分)

例:

1.1 消除左公共因子

1.2 消除左递归

1.3 找First集和Follow集

1.4 构造Select集

1.5 画出LL(1)分析预测表

2.Bottom-Up(10分)

Bottom-up语法分析方法一共有四种,范围依次是LR(1)  >  LALR(1)  >  SLR(1)  >  LR(0)

(这里一般考的是LR(1)型文法,判断某个文法是否是LR(1)文法,且该文法一般都有空串产生式)

四、语法制导翻译SDD(15分)

目前就只做过两种题,没有见过特别难的。

例一

例二

但是试卷上有个创新题,可能也是担心学生做不出来,这道题老师就给了五分。

五、中间代码生成(15分)

写三地址码。这里主要是一个回填的问题,其实吧,回填那一部分我也没咋听,我是凭感觉直接写的goto地址。

这里我也不保证我的答案全对哈,发现做的不一样的小伙伴可以一起交流。我也没找到标准答案。

六、运行时环境(10分)

画运行时的栈图。

其实也挺简单的,就按格式来就好了。主要还是记一下栈的内容,其实也不用记,考试卷子上会给你的

例题:

画出当栈达到最大时的栈图

解题思路:首先是先画一个函数调用的活动树;

                  然后看题,确定是哪一时刻的栈图。

七、代码优化(10分)

DAG优化。呃,这个懒得讲了,感觉给表弟讲下思路,他都能做对

这篇关于SEU编译原理复习(期末考试用)——知识点+习题练习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/604836

相关文章

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、