E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
编译原理代码题
go语言实现LRU缓存
go语言实现LRUCache题目描述详细
代码题
目描述设计和构建一个“最近最少使用”缓存,该缓存会删除最近最少使用的项目。
别人家的孩子zyh
·
2024-02-10 06:47
缓存
golang
LRU
力扣热题100_双指针_283_移动零
文章目录题目链接解题思路解题
代码题
目链接283.移动零给定一个数组nums,编写一个函数将所有0移动到数组的末尾,同时保持非零元素的相对顺序。请注意,必须在不复制数组的情况下原地对数组进行操作。
you_are_my_sunshine*
·
2024-02-10 06:04
力扣
leetcode
算法
力扣热题100_哈希_128_最长连续序列
文章目录题目链接解题思路解题
代码题
目链接128.最长连续序列给定一个未排序的整数数组nums,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。
you_are_my_sunshine*
·
2024-02-10 06:31
力扣
leetcode
哈希算法
算法
《
编译原理
》
第一章编译引论1、编译程序:将某一种程序设计语言写的程序翻译成等价的另一种语言的程序的程序2、源语言:用来编写源程序的语言(汇编,高级程序设计语言)3、源程序:用源语言写的程序4、目标语言:目标程序描述的语言5、目标程序:源程序经过编译后生成的程序6、宿主语言:编译程序的实现语言7、宿主机:编译程序的运行环境8、分类:解释程序【接受某语言的源程序将其直接翻译成目标代码且执行】;编译程序【接受某语言
曹元_
·
2024-02-09 12:48
编译原理
研究性学习专题 2——递归下降语法分析设计原理与实现
1实验内容完成以下描述赋值语句的LL(1)文法的递归下降分析程序G[S]:S→V=EE→TE’E’→ATE’|eT→FT’T’→MFT’|EF→(E)|iA→+|-M→*|/V→i设计说明:终结符号i为用户定义的简单变量,即标识符的定义。2实验要求(1)输入串应是词法分析的输出二元式序列,即某算术表达式“专题1”的输出结果,输出为输入串是否为该文法定义的算术表达式的判断结果;(2)递归下降分析程序
dor.yang
·
2024-02-09 10:24
课程作业记录博客
学习
java
前端
编译原理
递归下降
编译原理
(九)——递归下降法
背景:自定向下的语法分析方法,LL(1)是一种非常直观的方法,它的分析过程是按照句子的定义来进行的,也就是说从开始符出发对要分析的串进行推导,如果推导成功就证明这个被分析的串是一个合法的句子,否则的话就有语法错误,但是在推导过程中,对文法进行了一些限定,保证推导过程是唯一的。总体上说,LL(1)就是在选择规则的时候加入了约束条件,考虑到输入流中的第一个符号,以及推导过程中的非终极符的规则选择,只有
很注重数学和821
·
2024-02-09 10:54
编译原理
编译原理
实验2 语法分析——递归下降分析器
目录标题一、核心代码1.题目要求2.代码实现3.运行结果:二、实现加,减,乘,除运算的表达式文法1.题目要求2.代码实现3.运行结果一、核心代码1.题目要求练习构造递归下降语法分析程序的方法,熟悉上下文无关文法的使用,加深对课堂教学的理解;提高语法分析方法的实践能力文法G[E]:E→E+T|TT→T*F|FF→i|(E)消除左递归后:E→TXX→+TX|^T→FYY→*FY|^F→i|(E)要求:
学而时习之,不亦说乎?
·
2024-02-09 10:54
编译原理
——实验贰——递归下降语法分析器的构建
一、实验要求运用递归下降法,针对给定的上下文无关文法,给出实验方案。预估实验中可能出现的问题。二、实验方案1、构造LL(1),通过设计、编制、调试递归下降语法分析程序,对输入的符号串进行分析匹配,观察输入符号串是否为给定文法的句子。2、根据LL(1)写程序三、预估问题预估问题:LL(1)构造失败,程序报错理论基础:1、递归下降分析程序的实现思想是:识别程序由一组子程序组成。每个子程序对应于一个非终
赴约如期
·
2024-02-09 10:23
编译原理
与技术(三)——语法分析(二)自顶向下-递归下降
一、语法分析的两种方法自顶向下(Top-down):针对输入串,从文法的开始符号出发,尝试根据产生式规则推导(derive)出该输入串。从根部开始构造语法树。自底向上(Bottom-up):针对输入串,尝试根据产生式规则归约(reduce)到文法的开始符号。从叶子开始构造语法树。二、递归下降法举个例子。开始递归下降语法分析。匹配到数字”3”后,程序从expr返回。至此,递归下降分析结束。三、递归下
MCQSLW
·
2024-02-09 10:50
算法
最短路径中的分层图
目录题目描述题目分析分层图本题
代码题
目描述P4568[JLOI2011]飞行路线题目分析显然,这是一道最短路径的题目,我们可以选择DijkstraDijkstraDijkstra算法求解。
青年之家
·
2024-02-09 09:54
algorithms
luogu
算法
完全背包问题
目录题目描述解析
代码题
目描述有nnn个重量和价值分别为wiw_iwi,viv_ivi的物品。从这些物品中挑选出总重量不超过WWW的物品,求所有挑选方案中价值总和的最大值。
青年之家
·
2024-02-09 09:23
algorithms
算法
动态规划
【Makefile语法 01】编译系统
目录一、
编译原理
概述二、编译过程分析三、编译动静态库四、执行过程分析一、
编译原理
概述make:一个GCC工具程序,它会读makefile脚本来确定程序中的哪个部分需要编译和连接,然后发布必要的命令。
AllinTome
·
2024-02-09 03:57
Makefile语法
linux
运维
服务器
力扣热题100_哈希_1_两数之和
文章目录题目链接解题思路解题
代码题
目链接1.两数之和给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。
you_are_my_sunshine*
·
2024-02-09 03:14
力扣
leetcode
哈希算法
算法
leetcode(力扣) 49. 字母异位词分组 (哈希表)
文章目录题目描述思路分析完整
代码题
目描述给你一个字符串数组,请你将字母异位词组合在一起。可以按任意顺序返回结果列表。
深度不学习!!
·
2024-02-09 03:43
个人笔记
交流学习
leetcode
python
力扣热题100_哈希_49_字母异位词分组
文章目录题目链接解题思路解题
代码题
目链接49.字母异位词分组给你一个字符串数组,请你将字母异位词组合在一起。可以按任意顺序返回结果列表。字母异位词是由重新排列源单词的所有字母得到的一个新单词。
you_are_my_sunshine*
·
2024-02-09 03:11
力扣
leetcode
哈希算法
算法
【leetcode】144.二叉树的前序遍历
【leetcode】144.二叉树的前序遍历题目思路
代码题
目leetcode原题链接给你二叉树的根节点root,返回它节点值的前序遍历。
前端corner
·
2024-02-08 17:35
leetcode题解js
javascript
leetcode
前端
编译原理
实验1——词法分析(python实现)
文章目录实验目的实现定义单词对应的种别码定义输出形式:三元式python代码实现运行结果检错处理总结实验目的输入一个C语言代码串,输出单词流,识别对象包含关键字、标识符、整型浮点型字符串型常数、科学计数法、操作符和标点、注释等等。实现定义单词对应的种别码自行定义相关单词的种别码定义输出形式:三元式#三元式classThreeFml:#三元式def__init__(self,syn,inPoint,
在半岛铁盒里
·
2024-02-08 11:43
编译原理
python
编译原理
编译原理
实验2——自上而下语法分析LL1(包含去消除左递归、消除回溯)
文章目录实验目的实现流程代码运行结果测试1(含公共因子)测试2(经典的i+i*i文法,且含左递归)测试3(识别部分标识符)总结实验目的实现自上而下分析的LL1语法分析器,给出分析过程实现流程代码代码逻辑1.预处理去除多余空格:如“S->aB”,处理成“S->aB”拆解候选式:对于某一产生式,若有多个候选式,根据|符号拆解为多个产生式。获取开始符号:默认输入的第一个非终结符为开始符消除左递归和回溯(
在半岛铁盒里
·
2024-02-08 11:43
编译原理
python
编译原理
LL1分析
编译原理
实验3——自下而上的SLR1语法分析实现(包含画DFA转换图、建表、查表)
文章目录实验目的实现流程定义DFA状态实现代码运行结果测试1测试2测试3总结实验目的实现自下而上的SLR1语法分析,画出DFA图实现流程定义DFA状态classDFA:def__init__(self,id_,item_,next_ids_):self.id_=id_#编号self.item_=item_#productionsself.next_ids_=next_ids_#{v1:id1,v2
在半岛铁盒里
·
2024-02-08 11:42
编译原理
python
编译原理
SLR1
编译原理
(4):语法分析下——自底向上分析
声明:本系列文章,是根据中国大学MOOC网哈工大的
编译原理
这门课学习而成的学习笔记。
逢青丶
·
2024-02-08 11:17
编译原理
编译原理
--实验3-基于-LR(0)方法的语法分析
文章目录前言1.1实验目的1.2实验任务1.3实验内容1.3.1输入格式:1.3.2输出格式:1.3.3样例1.4程序1.4.1程序流程图1.4.2算法描述1.4.3程序源码前言
编译原理
课程实验的实验课内容
杨大熊的代码世界
·
2024-02-08 11:47
编译原理
编译原理
实验三 自下而上语法分析
一、实验目的(1)根据PL/0语言的文法规范,要求编写PL/0语言的语法分析程序。(2)通过设计、编制、调试一个典型的自下而上语法分析程序,实现对语法分析程序所提供的单词序列进行语法检查和结构分析,进一步掌握常用的语法分析方法。(3)选择最有代表性的语法分析方法,算符优先分析法、LR分析法;或者调研语法分析器的自动生成工具YACC的功能与工作原理,使用YACC生成一个自底向上的语法分析器。二、实验
up up up!
·
2024-02-08 11:46
编译原理
c++
编译器
【
编译原理
】简明自底向上分析算法总结:LR(0),SLR,LR(1),LALR分析算法
【
编译原理
】简明自顶向下分析算法总结:递归下降,LL(1)分析算法语法分析有两个总的思路,一个是自顶向下分析,一个是自底向上分析。
Catigeart
·
2024-02-08 11:46
编译原理
编译器
编译原理
与技术(三)——语法分析(四)自底向上-移进归约
五、冲突(一)移进-归约冲突(二)归约-归约冲突参考资料:[1]USTC
编译原理
和技术2023(ustc-compiler-principl
MCQSLW
·
2024-02-08 11:14
算法
编译原理
与技术(三)——语法分析(六)自底向上-SLR分析
(三)构造识别活前缀的DFA(四)从DFA构造SLR分析表四、SLR(1)文法参考资料:[1]USTC
编译原理
和技术2023(ustc-compiler-principles.github.io
MCQSLW
·
2024-02-08 11:14
编译原理与技术
语法分析
文法
SLR
编译原理
与技术(三)——语法分析(五)自底向上-LR分析
参考资料:[1]USTC
编译原理
和技术2023(ustc-compiler-principles.github.io)
MCQSLW
·
2024-02-08 11:44
算法
编译原理
与技术(三)——语法分析(七)自底向上-LR(1)分析
参考资料:[1]USTC
编译原理
和技术2023(ustc-com
MCQSLW
·
2024-02-08 11:43
编译原理与技术
语法分析
文法
LR
Java 学习路线之四个阶段
在这里特说明下,在大学期间一定要把一些基础的课程学好,比如:计算机系统、算法、
编译原理
等,这个对后期的学习
java开发资源分享
·
2024-02-07 22:48
音视频学习之路--NDK交叉编译解析
编译原理
这里主要说的是一个C/C++文件要经过下面4个步骤菜能变成可执行文件:预处理(p
蜗牛是不是牛
·
2024-02-07 19:37
LeetCode每日一题 | LCP 30. 魔塔游戏
文章目录题目描述问题分析程序
代码题
目描述原题链接小扣当前位于魔塔游戏第一层,共有N个房间,编号为0~N-1。
一根老麻花
·
2024-02-07 15:03
leetcode
游戏
算法
贪心算法
出租车计费 、靠谱的车
文章目录题目描述:出租车计费、靠谱的车输入描述输出描述用例解题思路
代码题
目描述:出租车计费、靠谱的车程序员小明打了一辆出租车去上班。出于职业敏感,他注意到这辆出租车的计费表有点问题,总是偏大。
-借我杀死庸碌的情怀-
·
2024-02-07 05:01
刷题
c语言
数据结构
编译原理
实验4 语义分析(基于PL/0,使用C++代码编写)
文章目录1实验任务2实验内容3错误类型声明4文件结构与代码4.1代码结构4.2详细代码4.3递归下降子程序的声明5常变量说明6运行结果1实验任务审查每一个语法结构的静态语义,即验证语法正确的结构是否有意义。此部分不再借助已有工具,需手写代码来完成。2实验内容(1)实验要求你的程序需要对输入文件进行语义分析并检查错误进行输出。(2)输入格式一个包含源代码的文本文件,程序需要能够接收一个输入文件名作为
Magic__Conch
·
2024-02-06 21:02
编译原理
编译原理
语义分析
编译原理
实验2 自顶向下的语法分析程序
文章目录1运行结果2项目代码3实验内容3.1实验内容说明3.2算法描述3.3程序结构3.4主要变量说明3.5工具函数1运行结果(1)测试文法一(输入文件产生式右部与句子全部以单个空格隔开,测试文法必须是LL(1)的):E->TE’E’->+TE’E’->#T->FT’T’->*FT’T’->#F->iF->(E)测试句子:i+i*i测试结果如下图所示(由于图太大,分割成几部分展示)。(2)测试文法
Magic__Conch
·
2024-02-06 21:31
编译原理
编译原理
语法分析
XCTF-攻防世界CTF平台-Web类——10、unserialize3(反序列化漏洞绕过__wakeup()函数)
打开题目地址:发现是一段残缺的php
代码题
目名称unserialize3就是反序列化,要求我们通过反序列化漏洞绕过__wakeup()函数。
大灬白
·
2024-02-06 17:13
#
Bugku
XCTF-WEB类写题过程
前端
php
web
web安全
安全
【力扣面试】面试题 05.03. 翻转数位
【力扣面试】面试题05.03.翻转数位文章目录题目解题思路
代码题
目给定一个32位整数num,你可以将一个数位从0变为1。请编写一个程序,找出你能够获得的最长的一串1的长度。
克利斯提亚诺-梅西
·
2024-02-06 09:55
LeetCode刷题
面试
编译原理
实验1——词法分析程序设计原理与实现
1.理论传授源程序输入与词法分析程序输出的基本方法;正则文法及其状态转换图的基本概念,正则表达式及有限自动机的基本概念;正规文法构造相应的状态转换图的基本方法;正则表达式构造有限自动机的基本方法及不确定有限自动机确定化的基本方法;词法分析程序的设计与编写。2.目标任务给出补充后描述C语言子集单词符号的正则文法,设计并实现其词法分析程序。[设计说明](1)可将该语言设计成大小写不敏感,也可设计成大小
dor.yang
·
2024-02-06 08:39
课程作业记录博客
正则表达式
编辑器
词法分析
编译原理
(四)——自动机与正则表达式
一、自动机与正则表达式的关系DFA\NFA\正则表达式三者都可以一一对应寻找。1.1DFA到正则表达式结构化程序语言:顺序、分支、循环目前涉及到的都是结构化程序语言,非结构化程序语言不做要求。(非结构化转换成结构化再转换成正则表达式)记住上面三种基本的转化方式即可,其余方式都是由以上的方式组合而成。终止状态集的处理增加一个终止状态,所有原有的终止状态都有一个null输入转换为同一个终止状态,然后进
很注重数学和821
·
2024-02-06 08:08
编译原理
【
编译原理
】正则表达式转NFA
第一步:读入正则表达式从txt文件中读入正则表达式#include#include#include#include#include#defineMAX_TOKEN100usingnamespacestd;//词structToken{stringname;//词的名字stringregExp;//正则表达式vectorfinalState;//终态};intreadTXT(stringfileNa
倒过来是圈圈
·
2024-02-06 08:38
编译原理
正则表达式
非确定性有穷自动机
编译原理
与技术(三)——语法分析(一)上下文无关文法
一、语法分析概貌通过词法分析,我们可以获取一个程序字符串的词法单元集合。编过程序的都知道,每个程序都有其语法,那么问题来了,我们怎么判断这些词法单元符合语法呢?编程的错误之一不就是语法错误吗?所以,我们必须找出一种判断程序字符串是否符合语法的方法。判断程序是否符合语法的过程就是语法分析。下面介绍一位在编译技术领域做出巨大贡献的科学家——JohnBackus。JohnBackus带领团队创建了第一种
MCQSLW
·
2024-02-06 08:35
数学建模
编译原理
与技术(二)——词法分析(三)词法分析器的构造
词法分析器就是NFA或DFA,这从前面可以看出。虽然DFA比NFA快,但其特性少,而NFA则特性丰富。所以在实际应用中,NFA作为词法分析器反而应用更加广泛。像Python与Ruby的RE模块都是NFA的。本节重点讲如何构造一个词法分析器,即如何构造一个NFA、DFA与化简的DFA。一、NFA的构造下面介绍一个构造NFA的算法——语法制导的构造算法。按如上方法与顺序便可构造出一个NFA。由上述方法
MCQSLW
·
2024-02-06 08:05
数学建模
编译原理
与技术(二)——词法分析(一)正则表达式
一、词法分析的概貌一个程序,在我们看来往往是像下图这样的。实际上,上面的程序本质上就是一个字符串,所以,它等价于下面这样的。上面的字符串(字符流),就是编译器接收到的程序的形式。所以,编译器首先要对字符流进行断句,即将输入字符串识别为有意义的子串,删去注释和无意义的换行符等字符。有意义的子串又叫词法单元(token)。从程序字符流中获取词法单元集合的过程就是词法分析。二、词法单元词法单元(toke
MCQSLW
·
2024-02-06 08:32
正则表达式
Nim游戏
文章目录题目描述输入格式输出格式结论程序
代码题
目描述给定n堆石子,两位玩家轮流操作,每次操作可以从任意一堆石子中拿走任意数量的石子(可以拿完,但不能不拿),最后无法进行操作的人视为失败。
一根老麻花
·
2024-02-06 07:13
游戏
c++
算法
博弈论
LeetCode每日一题 | 1696. 跳跃游戏 VI
文章目录题目描述问题分析程序
代码题
目描述给你一个下标从0开始的整数数组nums和一个整数k。一开始你在下标0处。每一步,你最多可以往前跳k步,但你不能跳出数组的边界。
一根老麻花
·
2024-02-06 07:07
leetcode
游戏
算法
双端队列
【程序员的自我修养11】栈与函数调用过程
编译原理
相关知识本身就比较有难度,我会尽自己最大的努力,争取深入浅出。若你希望与一群志同道合的朋友一起学习,也希望加入到我们的学习群中。文末有加入方式。
谢艺华
·
2024-02-06 05:21
编译
链接
装载
库
java
数据库
服务器
栈帧
LeetCode206 反转链表
反转链表在bilibili上的视频讲解:https://www.bilibili.com/video/BV1ei4y1Y7yF/文章目录题目描述解题思路思路步骤思路动画代码Python代码C++代码Java
代码题
目描述给你单链表的头节点
爱科研的瞌睡虫
·
2024-02-05 09:28
链表
数据结构
leetcode
算法
编译原理
本科课程 专题4 算符优先语法分析设计原理与实现
一、程序功能描述本程序由C/C++编写,实现了:算符优先文法、最左素短语、算符优先矩阵、优先函程序等概念的定义及实例。以专题1词法分析程序的输出为语法分析的输入,实现算符优先分析算法,完成以下描述算术表达式的算符优先文法的算符优先分析过程:G[E]:E→E+T∣E-T∣TT→T*F∣T/F∣FF→(E)∣i二、主要数据结构描述关于具体的数据结构,主要使用了C语言的数组,其中字符数组运用最多,主要用
11egativ1ty
·
2024-02-05 08:38
编译原理
网络
编译原理
本科课程 专题5 基于 SLR(1)分析的语义分析及中间代码生成程序设计
一、程序功能描述本程序由C/C++编写,实现了赋值语句语法制导生成四元式,并完成了语法分析和语义分析过程。以专题1词法分析程序的输出为语法分析的输入,完成以下描述赋值语句SLR(1)文法的语义分析及中间代码四元式的过程,实现编译器前端。G[S]:S→V=EE→E+T∣E-T∣TT→T*F∣T/F∣FF→(E)∣iV→i二、主要数据结构描述关于本程序的数据结构,首先用map存储了非终结符及终结符的编
11egativ1ty
·
2024-02-05 08:38
编译原理
c++
编译原理
本科课程 专题3 LL(1)语法分析设计
一、程序功能描述本程序由C/C++编写,运用了自顶向下语法分析的设计方法和实现原理,实现了:LL(1)分析表的构造、LL(1)分析过程、LL(1)分析器的构造。程序以专题1词法分析程序的输出为语法分析的输入,实现了LL(1)分析中控制程序(表驱动程序),完成了以下描述赋值语句的LL(1)文法的LL(1)分析过程:G[S]:S→V=EE→TE′E′→ATE′|εT→FT′T′→MFT′|εF→(E)
11egativ1ty
·
2024-02-05 08:08
编译原理
java
数据库
服务器
《一天看完
编译原理
》--
编译原理
(第三版)蒋立源(奖励员?)
考试导向,个人复习用,因为基本没去上过课,所以应该不会侵害学校的知识产权(第一章绪论
编译原理
就是处理字符串,输入给自动机的就是一大段string,整个compiler就是把输入的符号串,根据文法,生成另一组符号串
11egativ1ty
·
2024-02-05 08:37
编译原理
学习
Leetcode2-两数相加代码详解
Leetcode2-两数相加文章目录Leetcode2-两数相加题目一、示例解析迭代法伪代码python代码递归法伪代码python
代码题
目给你两个非空的链表,表示两个非负的整数。
白羊by
·
2024-02-05 03:34
力扣算法题-python
开发语言
python
迭代法
递归法
leetcode
上一页
1
2
3
4
5
6
7
8
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他