梧桐数据库(WuTongDB):数据库技术中LL算法详解
LL 算法是一种自顶向下的语法分析算法,广泛用于构建解析器。LL 分析器逐个读取输入符号,从左到右分析(Left-to-Right),并使用最左推导(Leftmost Derivation)来生成语法树。因此,LL 分析器通常称为 “预测分析器”。
LL 算法的基本原理
LL 算法的核心思想是通过查看输入符号并结合预测集来确定下一步应采取的推导规则。具体来说,LL(k) 分析器使用最多 k 个符号来进行预测。最常见的 LL 分析器是 LL(1),它只使用一个符号来进行预测。
文法示例
考虑以下文法:
S -> A B
A -> a | ε
B -> b
S是起始符号。A和B是非终结符号。a和b是终结符号。ε表示空串(即可以不生成任何符号)。
LL(1) 分析器的构建步骤
-
消除左递归(如有):LL 分析器不能直接处理左递归,因此首先需要对文法进行预处理,消除任何左递归。
-
提取左公因子(如有):对于文法规则中存在共同前缀的情况,可以通过提取左公因子来避免冲突。例如,将
A -> aX | aY改为A -> aZ, Z -> X | Y。 -
构建 FIRST 集:
FIRST(X)是指可以作为符号X(终结符或非终结符)开头的所有可能的终结符号的集合。- 对于一个终结符
a,FIRST(a)就是{a}。 - 对于一个非终结符
A,如果A的某个推导式A -> X1 X2 ... Xn可以产生某个终结符a,那么a属于FIRST(A)。
-
构建 FOLLOW 集:
FOLLOW(A)是指符号A后可能出现的终结符号的集合。- 如果存在一个推导式
S -> αAβ,那么FIRST(β)中的所有符号都属于FOLLOW(A)。 - 如果
β可以推导为空串(即ε),那么FOLLOW(S)中的所有符号也属于FOLLOW(A)。
-
构建预测分析表:
- 预测分析表是一个二维表,行是非终结符号,列是终结符号。
- 根据
FIRST和FOLLOW集填充表格:对于每个产生式A -> α,如果终结符号a属于FIRST(α),则在表格的A行和a列填入该产生式。
LL(1) 分析器的工作流程
-
初始化:将输入字符串放入分析器,初始化栈(通常栈的底部有一个结束符
#,表示输入结束)。 -
栈操作与预测表查找:
- 初始时,将起始符号
S压入栈。 - 循环:检查栈顶符号与当前输入符号。
- 如果栈顶是终结符号且与当前输入符号匹配,则从栈中弹出该符号,并将输入移至下一个符号。
- 如果栈顶是非终结符号,查找预测分析表,使用表中产生式替换栈顶符号。
- 如果无法匹配,则表示语法错误。
- 初始时,将起始符号
-
结束条件:当栈为空且输入符号全部处理完毕,则分析成功。
示例解析过程
我们用上面提到的简单文法来解析输入串 ab:
-
构建 FIRST 集:
FIRST(A) = {a, ε}FIRST(B) = {b}FIRST(S) = {a, b}
-
构建 FOLLOW 集:
FOLLOW(S) = {#}FOLLOW(A) = {b}FOLLOW(B) = {#}
-
构建预测分析表:
S -> AB填入表中(S, a)和(S, b)位置。A -> a填入(A, a)位置。A -> ε填入(A, b)位置。B -> b填入(B, b)位置。
-
分析输入
ab:- 栈初始状态:
[#, S] - 读入
a,查表(S, a),找到产生式S -> AB,栈状态变为[#, B, A] - 栈顶是
A,读入a,查表(A, a),找到产生式A -> a,栈状态变为[#, B] - 栈顶是
B,读入b,查表(B, b),找到产生式B -> b,栈状态变为[#] - 输入符号和栈符号都匹配且已处理完,分析成功。
- 栈初始状态:
LL(1) 文法的局限性
- 不能处理左递归文法:如前所述,LL(1) 分析器不能直接处理左递归文法,需消除左递归。
- 不能处理具有多个候选项的复杂文法:如果文法中存在某个非终结符号的多个候选项,这些候选项的
FIRST集存在交集,LL(1) 分析器将无法区分这些候选项。
总结
LL(1) 算法是一种简单且高效的语法分析方法,适合解析 LL(1) 文法。它通过预测分析表进行符号匹配和规则推导。尽管 LL(1) 算法不能处理所有上下文无关文法,但其简单性和可预测性使其在编译器设计中广受欢迎。
产品简介
- 梧桐数据库(WuTongDB)是基于 Apache HAWQ 打造的一款分布式 OLAP 数据库。产品通过存算分离架构提供高可用、高可靠、高扩展能力,实现了向量化计算引擎提供极速数据分析能力,通过多异构存储关联查询实现湖仓融合能力,可以帮助企业用户轻松构建核心数仓和湖仓一体数据平台。
- 2023年6月,梧桐数据库(WuTongDB)产品通过信通院可信数据库分布式分析型数据库基础能力测评,在基础能力、运维能力、兼容性、安全性、高可用、高扩展方面获得认可。
点击访问:
梧桐数据库(WuTongDB)相关文章
梧桐数据库(WuTongDB)产品宣传材料
梧桐数据库(WuTongDB)百科
相关文章:
梧桐数据库(WuTongDB):数据库技术中LL算法详解
LL 算法是一种自顶向下的语法分析算法,广泛用于构建解析器。LL 分析器逐个读取输入符号,从左到右分析(Left-to-Right),并使用最左推导(Leftmost Derivation)来生成语法树。因此,LL 分…...
【秋招笔试】8.18大疆秋招(第一套)-后端岗
🍭 大家好这里是 春秋招笔试突围,一起备战大厂笔试 💻 ACM金牌团队🏅️ | 多次AK大厂笔试 | 编程一对一辅导 ✨ 本系列打算持续跟新 春秋招笔试题 👏 感谢大家的订阅➕ 和 喜欢💗 和 手里的小花花🌸 ✨ 笔试合集传送们 -> 🧷春秋招笔试合集 🍒 本专栏已收…...
CSS 的text-size-adjust属性
text-size-adjust 属性在CSS中用于控制用户是否可以调整网页中文字的字体大小。这个属性主要针对移动设备上的浏览器,尤其是那些允许用户通过捏合(pinch)手势来缩放整个页面的浏览器。 语法 text-size-adjust: none; text-size-adjust: aut…...
阿里MAXCOMPUTE数据专辑信息读取并同步数据表
阿里MAXCOMPUTE数据专辑信息读取并同步数据表 在阿里云大数据体系中,我们可以使用数据地图的数据专辑,对数据的类别等进行一个管理 那么管理后的数据,我们想要落表进行相关的数据分析,如何做呢? 查看阿里云官方文档…...
rufus制作ubantu的U盘安装介质时,rufus界面上的分区类型选什么?
rufus制作ubantu的U盘安装介质时,rufus软件界面上的分区类型选什么(如下图)? 在使用Rufus制作Ubuntu的U盘安装介质时,分区类型的选择取决于我们的计算机的引导方式。 以下是具体的选择建议: 1、查看计算机的引导方式…...
【系统架构设计师-2018年】案例分析-答案及详解
试题一(25分) 阅读以下关于软件系统设计的叙述,在答题纸上回答问题1至问题3。 【说明】 某文化产业集团委托软件公司开发一套文化用品商城系统,业务涉及文化用品销售、定制、竞拍和点评等板块,以提升商城的信息化建设…...
linux驱动入门实验班——平台总线设备驱动模型和设备树
目录 前言 一、重要结构体 二、编程思路 1.platform_driver结构体 2.probe 三、使用设备树 1.步进电机 2.红外遥控 四、代码示例 前言 在这里主要记录学习韦东山老师Linux驱动人入门实验班的笔记,韦东山老师的驱动课程讲的非常好,想要学习驱动…...
零基础学习Python(六)
1. 元类的应用 使用元类给对象添加一个固有属性author: 对类名进行限定,要求类名必须是大写字母开头: class MetaC(type):def __init__(cls, name, bases, attrs):if not name.istitle():raise TypeError("类名必须是大写字母开头~")return …...
微信小程序--31(todolist案例)
一.功能 输入待办事件添加代办事件删除代办事件 二、步骤 1.添加输入框 .wxml代码: <!-- 1.输入框 --><input type"text" bindinput"handleInput" value"{{text}}" /> .wxss代码: /* 1.输入框样式 */ i…...
springboot项目使用本地依赖项,打包后出现NoClassDefFoundError的一种解决方法
可以把本地依赖项上传到本地仓库后再引用 建立 Maven 本地仓库并将依赖上传到本地仓库 要建立 Maven 本地仓库并将依赖上传到本地仓库,可以按照以下步骤进行操作: 1. 配置 Maven 本地仓库路径 Maven 默认会在用户的主目录下的 .m2/repository 目录创…...
Maven高级使用指南
在开发大型项目时,Maven作为一个强大的构建和项目管理工具,能显著提升项目管理和构建的效率。然而,随着项目的扩大,维护和管理的复杂性也随之增加。本文将探讨一些高级的Maven用法和解决方案,以帮助你更好地管理大型项…...
windows docker 执行apt-get 权限问题
今天在windows下安装的docker 部署的容器执行apt-get遇到权限问题 PS C:\Users\xiaok> docker exec -it jenkins sh $ apt-get update Reading package lists... Done E: Could not open lock file /var/lib/apt/lists/lock - open (13: Permission denied) E: Unable to l…...
Linux系统信息排查
目录 介绍步骤 介绍 1、熟悉查看CPU信息、操作系统信息、用户信息、特殊权限账户、启动项和任务计划的排查命令 2、在进行受害主机排查时,首先要对主机系统进行基本排查,方便对受害主机有一个初步的了解。 3、利用lscpu和uname -a查看系统硬件软件基本…...
《图解设计模式》笔记(四)分开考虑
九、Bridge模式:将类的功能层次结构与实现层次结构分离 类的两个层次结构和作用 类的功能层次结构:希望增加新功能时 父类有基本功能,在子类中增加新功能 Something父类 …├─SomethingGood子类 想要再增加新功能 Something父类 …├─So…...
Linux shell编程学习笔记74:sed命令——沧海横流任我行(中)
0 前言 自 60 年代末以来,sed 一直是 Unix 标准工具箱的一部分。 Sed在以下三种情况下特别有用: 编辑太大的文件,无法进行舒适的交互式编辑; 当编辑命令序列过于复杂而无法在交互模式下轻松键入时,可以编辑任何大小的…...
[数据集][目标检测]道路积水检测数据集VOC+YOLO格式2699张1类别
数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2699 标注数量(xml文件个数):2699 标注数量(txt文件个数):2699 标注…...
不同路径
不同路径 思路: 法一:动态规划 const int N 110; class Solution { int dp[N][N];//dp[i][j]:从起点走到 i j的路径个数。 public:int uniquePaths(int m, int n) {for(int i1;i<n;i){dp[1][i]1;} for(int i1;i<m;i) dp[i][1]1;f…...
【HTML】HTML学习之引入CSS样式表
1、CSS样式规则 选择器{属性1:属性值1; 属性2:属性值2; 属性3:属性值3;}2、HTML引入CSS样式表 2.1、行内式 行内式也称为内联样式,是通过标签的style属性来设置元素的样式,其基本语法格式如下: <标签名 style"属性1:属性值1; 属性2:属性值2;…...
shaushaushau1
CVE-2023-7130 靶标介绍: College Notes Gallery 2.0 允许通过“/notes/login.php”中的参数‘user’进行 SQL 注入。利用这个问题可能会使攻击者有机会破坏应用程序,访问或修改数据. 已经告诉你在哪里存在sql注入了,一般上来应该先目录扫…...
揭秘面试必备:高频算法与面试题全面解析
干货分享,感谢您的阅读! (暂存篇---后续会删除,完整版和持续更新见高频面试题基本总结回顾(含笔试高频算法整理)) 备注:引用请标注出处,同时存在的问题请在相关博客留言…...
LEANN:基于选择性重计算的本地向量检索,实现97%存储压缩
1. 项目概述:LEANN,一个重新定义本地向量检索的开源项目如果你和我一样,对当前AI应用生态里动辄需要将个人数据上传到云端、依赖昂贵且臃肿的向量数据库感到厌倦,那么LEANN的出现,绝对会让你眼前一亮。这不仅仅是一个工…...
无守护进程容器镜像构建:Tiny Builder 原理、实践与CI/CD集成指南
1. 项目概述:一个极简的容器镜像构建器最近在折腾容器化部署和CI/CD流水线时,我一直在寻找一个足够轻量、纯粹的镜像构建工具。Docker本身当然没问题,但有时候,尤其是在一些资源受限的环境(比如GitHub Actions的免费Ru…...
Cadence Allegro自定义快捷键全攻略:从env文件到Skill脚本
1. 项目概述:为什么我们需要自定义快捷键?如果你是一名电子工程师,或者经常使用Cadence Allegro进行PCB设计,那么对软件自带的默认快捷键一定又爱又恨。爱的是,它确实提供了一些基础的操作加速;恨的是&…...
RISC-V PLIC中断控制器详解:从原理到SiFive U54实战配置
1. 平台级中断控制器(PLIC)是什么?为什么需要它?如果你正在接触基于RISC-V架构的嵌入式系统开发,尤其是像SiFive U54这样的多核处理器,那么“PLIC”这个缩写会频繁地出现在你的视野里。它全称是Platform-Le…...
知识图谱嵌入模型全解析:从TransE到RotatE的演进与实战指南
1. 项目概述:为什么我们需要重新审视KGE?在信息爆炸的时代,我们每天都在和“关系”打交道:社交网络中的好友关系、电商平台上的购买关系、学术论文间的引用关系。如何让机器理解这些错综复杂的实体与关系,并从中挖掘出…...
如何高效应用思源宋体:设计师的5个专业字体应用技巧
如何高效应用思源宋体:设计师的5个专业字体应用技巧 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为中文排版设计烦恼吗?思源宋体CN作为一款免费开源的专…...
魔兽世界宏编辑器终极指南:5分钟掌握GSE高级技能自动化
魔兽世界宏编辑器终极指南:5分钟掌握GSE高级技能自动化 【免费下载链接】GSE-Advanced-Macro-Compiler GSE is an alternative advanced macro editor and engine for World of Warcraft. 项目地址: https://gitcode.com/gh_mirrors/gs/GSE-Advanced-Macro-Compi…...
VR技术如何革新无障碍设计:Empath-D系统实践
1. VR技术赋能无障碍设计的创新实践作为一名长期关注人机交互技术的开发者,我亲历了VR技术从娱乐工具到专业设计辅助的转型过程。Empath-D系统的出现标志着无障碍设计进入了"共情式开发"的新阶段——开发者不再需要凭空想象用户需求,而是能真正…...
StockSharp开源量化交易平台:C#/.NET生态的一站式解决方案
1. 项目概述:一个开源的量化交易与市场数据平台 如果你在金融科技、量化交易或者自动化交易系统开发领域摸爬滚打过一段时间,那么“StockSharp”这个名字大概率会出现在你的雷达上。它不是一个简单的库,而是一个庞大、成熟且野心勃勃的开源项…...
如何在Electron应用中集成Supertonic:实现离线语音功能的完整指南 [特殊字符]️
如何在Electron应用中集成Supertonic:实现离线语音功能的完整指南 🎙️ 【免费下载链接】supertonic Lightning-Fast, On-Device, Multilingual TTS — running natively via ONNX. 项目地址: https://gitcode.com/GitHub_Trending/sup/supertonic …...
