形式语言与自动机总结---上下文无关文法(CFG)

news2025/1/15 23:43:01

 第5章上下文无关文法:

设计文法:

做题的时候发现了一个正则表达式到文法的算法 R规则

根据正则式推导右线性文法_右线性文法表达ab*_Pluto °的博客-CSDN博客

举例

设计文法的关键在于理解递归性,文法是一个迭代器

1.The set {a^{i}b^{j}c^{k}| i ≠ j or j ≠ k}, that is, the set of strings of a's followed by b's followed by c's, such that there are either a different number of a's and b's or a different number of b's and c's, or both.

上方的做法是错误的做法 因为没有考虑i=j=k的情况。

 修改之后的结果

2.The set {a^{i}b^{j}c^{k}|i=j|j=k} is generated by G = ( { S , T , U , A , C } , { a , b , c } , P , S )) with production P:

3.请为语言L = {0^{n}1^{m} m\neq n}设计文法 

 4.设计0、1构成的串的文法,0 1数量不相等.

  • S\rightarrow X_{1}|X_{2}
  • E\rightarrow1E0E|E0E1E|\varepsilon
  • X_{1}\rightarrow Y_{1}X_{1} | Y_{1}
  • Y_1\rightarrow E1E
  • Y_2\rightarrow E0E

 5. The set of all strings 0’s and 1’s that are not of the form ww, that is , not equal to any string repeated.

  • S\rightarrow A|B|AB|BA
  • A\rightarrow CAC|a
  • B\rightarrow CBC|b
  • C\rightarrow a|b

6.The set of all strings with twice as many 0's as 1's.

                                S\rightarrow S0S0S1S|S0S1S0S|S1S0S0S|\varepsilon 

7.设计 Lj≥2i = {a^{i}b^{j}| j ≥ 2i} 的文法. 

  • S→AB
  • A→aAbb I 空串
  • B→Bb I 空串

8. L= { 0^{n}1^{n} | n \geq0 and n\neq3} 

  •  S\rightarrow \varepsilon |01|0011|0000A1111
  • A\rightarrow 0A1|\varepsilon

9.L(0 0* 11* 22* 00* 11* 22* 00* 11* 22*)  Hint : The language defined by the regular expression.

 分析:看起来像是012202012然后每一个的子字符可以重复,(00^{*}11^{*}22^{*})^{3}

  • S\rightarrow AAA 相当于三次方
  • A\rightarrow 0A_{1}1B2C
  • A_1\rightarrow 0A_{1}|\varepsilon
  • B\rightarrow 1B|\varepsilon
  • C\rightarrow 2C|\varepsilon

10. L = { a^{i}b^{j}|i\neq jand i\neq 2j|} 

explaination:分成两种情况:i\neq j \, \, and \,\, i \neq 2j

                                        \Rightarrow i<j\, \, |\, \, j<i<2j\, \, |i>2j

   S\rightarrow X_{1}|X_{2}|X_{3}

11.L ={ {a^{i}b^{j}c^{k}|i+j\neq k}}

验证某个串是否在文法中:派生 使用树来判断字符串是否在文法中

12.构造右线性文法:

 (1)S\rightarrow AB|BA

A\rightarrow aA|\varepsilon     B\rightarrow bB | \varepsilon

 (2)S\rightarrow aS\, \, |\,\,bS\,\,|abb

 (3)S\rightarrow bA \,\,\,\,\,\,\, A\rightarrow aA|a

 (4) 正则语言是(a+b)*(aa+bb)*(a+b)* 所以根据R规则 

S\rightarrow (a+b)S\,\,|\,\,bbA\,\,|\,\,aaA

A\rightarrow (a+b)A\,\,| \varepsilon A\rightarrow (a+b)A|\varepsilon

13. Design CFG for strings in {0,1} * in which the number of 0s is greater than or equal to the number of 1s.

S\rightarrow 0S1|1S0|SS|0S|\varepsilon

14.Design CFG for L = {w ∈ {(, )} ∗ | w is a string of balanced parentheses}.(括号匹配)

S\rightarrow \,S(S)S|\varepsilon

S\rightarrow (S)|SS|\varepsilon

15.L ={ a^{i}b^{j}c^{k}(i+j=k)} 感觉构造PDA然后转换比较简单

S\rightarrow aDc|\varepsilon

D\rightarrow aDb|\varepsilon

16 L ={a^{i}b^{j}c^{k}(j=2(i+k))}的CFG

S\rightarrow AB

A\rightarrow aBbb|\varepsilon

B\rightarrow bbBc|\varepsilon

17.L={a^{i}b^{j}c^{k}(k=i+j)} 的CFG

S\rightarrow aDc

D\rightarrow bDc|\varepsilon

文法的歧义性 

1.判断一个语言具有歧义性,画出两种树

2.让你消除歧义性:重新设计文法。

文法的化简

消除无用的符号

一定要注意顺序

  • 先消除产生的
  • 再消除可达的
  • 否则消除不干净

 先消除非产生的S\rightarrow a A\rightarrow b

再消除非可达的S\rightarrow a

 为啥要化简:自动机不能识别空产生式,多一步生成的操作 注意顺序的问题,有利于优化编译器的识别。

消除空产生式:

 S\rightarrow AB|A|B

A\rightarrow aA|a

B\rightarrow bB|b

消除单元产生式

文法化简可靠顺序 

消除无用符号 

 CNF范式

 算法:

 

PDA转换成CFG 

泵引理

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

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

相关文章

AIGC时代,分享11款超实用AI生成内容检测工具

前往未来百科查看全部AI内容检测工具箱 一、AI 内容检测器 在数字内容创作的世界中&#xff0c;高质量的内容对至关重要。但随着创建的内容量不断增加&#xff0c;确保内容是原创的、高质量的非常具有挑战性。 AI 内容检测器指的是一种利用人工智能技术来自动化审核和识别不当…

进程优先级

目录&#xff1a; 1.进程优先级的概念 2.查看进程优先级的方案 3.linux当中进程的优先级共有40个级别 4.对于进程的其它概念 ---------------------------------------------------------------------------------------------------------------------- 1.进程优先级的概念 为…

Talk预告 | ICLR‘23 斯坦福大学计算机系博士后吴泰霖:学习可控的自适应多分辨率物理仿真

本期为TechBeat人工智能社区第478期线上Talk&#xff01; 北京时间3月8日(周三)20:00&#xff0c;斯坦福大学计算机系博士后——吴泰霖的Talk将准时在TechBeat人工智能社区开播&#xff01; 他与大家分享的主题是: “学习可控的自适应多分辨率物理仿真”&#xff0c;届时将分…

灌区泵站及闸门控制自动化系统

根据灌区泵站及闸门控制现状&#xff0c;利用智能终端与互联网相结合方法&#xff0c;实施取水、输水、供水、灌溉、排水、防洪和水资源管理等自动控制系统&#xff0c;实现骨干渠道灌排闸门现场及远程自动控制和远程监测监视&#xff0c;达到计划配水、精准灌溉&#xff0c;高…

AJAX起步入门——介绍和使用

Ajax起步入门——介绍和使用基本用例场景复现核心干货AJAX简介ajax是什么&#xff1f;ajax工作原理ajax是基于现有的Internet标准AJAX实例实例演示实例代码ajax实例解析场景复现 最近学习与前端相关的小程序时&#xff0c;接触了异步请求api的封装和实现&#xff0c;涉及到了很…

多线程并发编程笔记07(小滴课堂)容器

同步容器 我们写这样一段代码。 我们想对vector容器在遍历时&#xff0c;去根据条件删除&#xff1a; 会出现异常。 那正确的方式应该如何去写呢&#xff0c;这里就涉及到了迭代器&#xff1a; 单线程中我们是这么做的。 那么多线程中呢&#xff1f; 有的时候它会报这个错误…

ChatGPT最强对手Claude使用教程

Cladue最近很火&#xff0c;作为ChatGPT4的平替版&#xff0c;它无需付费&#xff0c;使用方便&#xff0c;很多网友通过效果对比&#xff0c;发现它的性能要好于ChatGPT3.5&#xff0c;可以媲美ChatGPT4。最主要是使用很方便&#xff0c;十分钟就可以轻松部署&#xff0c;下面…

MongoDB初认识

MongoDB初认识 文章目录MongoDB初认识0. 写在前面1. MongoDB是什么2. MongoDB的优缺点3. 基础概念解析4. 安装4.1 下载地址4.2 安装MongoDB4.3 pgrep使用4.4 进入 shell 交互页面0. 写在前面 Linux版本&#xff1a;CentOS7.5 MongoDB版本&#xff1a;MongoDB-5.0.2&#xff08…

asp.net博客管理系统统VS开发sqlserver数据库web结构c#编程Microsoft Visual Studio

一、源码特点 asp.net博客管理系统 是一套完善的web设计管理系统&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为vs2010&#xff0c;数据库为sqlserver2008&#xff0c;使用c#语言开发 。 二、功能介绍 普通的用户是 123 密…

国产化ChatGPT来袭,景联文科技提供专业数据采集标注服务,人手一个专属ChatGPT或成为可能

ChatGPT作为一个颠覆性的创新&#xff0c;现已成为火爆全球的智能应用。 自ChatGPT爆火以来&#xff0c;国内科技圈开始频频发力&#xff0c;多家科技和互联网公司纷纷表示将开发出中国本土化的ChatGPT。 以百度为例&#xff0c;3月16日&#xff0c;百度推出新一代知识增强大语…

Doris数据模型

Doris支持三种数据模型&#xff0c;分别是&#xff1a; Aggregate Model&#xff08;聚合模型&#xff09; Unique Model&#xff08;唯一模型&#xff09; Duplicate Model&#xff08;冗余模型&#xff09; Aggregate Model&#xff08;聚合模型&#xff09; key相同的数…

影子账户——权限维持

文章目录定义创建定义 拥有管理员权限&#xff0c;但除了注册表外均查不到的账户。 创建 1、以管理员身份打开命令提示符 2、创建隐藏用户 3、将隐藏用户添加到管理员组 查看一下&#xff0c;没有显示匿名用户 4、查看《本地用户和组》&#xff0c;我是家庭版Windows&#x…

MySQL的学习

文章目录一、MySQL 插入数据二、MySQL 查询数据三、MySQL WHERE 子句四、MySQL UPDATE 更新五、MySQL DELETE 语句总结一、MySQL 插入数据 MySQL 表中使用 INSERT INTO SQL语句来插入数据。 你可以通过 mysql> 命令提示窗口中向数据表中插入数据&#xff0c;或者通过PHP脚…

Linux学习笔记——网络基础一

文章目录计算机网络发展过程独立模式网络互联局域网LAN广域网WAN计算机网络协议的概念网络协议协议分层OSI七层模型TCP/IP五层(或四层)模型网络传输基本流程数据包封装和分用各层间通信IP地址MAC地址计算机网络发展过程 独立模式 计算机之间相互独立; 网络互联 多台计算机连…

rc.local脚本延时启动

rc.local脚本延时启动1、问题描述2、解决方法3、rc.local脚本依赖关系的处理3.1、对脚本进行分类&#xff0c;分别设置延时启动策略4、测试重启rc-local.service5、rc.local脚本执行特点5.1、rc.local脚本在操作系统启动时只执行一次。5.2、在rc.local脚本中执行程序时是没有环…

人工智能专题-知识表示

文章目录人工智能专题-知识表示大纲2.1 知识表示的概念2.1.1 知识表示观点2.1.2 知识表示的要求2.2 一阶谓词逻辑表示法2.2.1 一阶谓词概念2.2.2 谓词逻辑表示方法2.3 产生式表示法2.4 语义网络表示法2.5 框架表示法人工智能专题-知识表示 大纲 大纲&#xff1a;掌握知识表示方…

jenkins——环境变量、节点配置以及节点环境变量的使用

这里写目录标题一、Jenkins 环境变量1、环境变量分类a、系统内置环境变量b、用户自定义环境变量2、环境变量的使用3、控制台输出二、Jenkins 节点配置1、Jenkins的常用节点2、准备工作3、SSH类节点配置4、Java web节点配置5、Java web节点配置详细步骤三、Jenkins 节点环境变量…

“三箭齐发”,诸葛智能三大产品全新升级,助力企业迈向数字化经营 | 爱分析调研

调研&#xff1a;文鸿伟 撰写&#xff1a;文鸿伟 诸葛智能&#xff0c;是容联云旗下敏捷开放的场景化数据智能服务商&#xff0c;累积服务全国1000企业&#xff0c;覆盖泛互联网、泛电商、金融、汽车、产业科技、企服等数十个垂直领域。 自2015年成立至今&#xff0c;诸葛智…

HTML5 <li> 标签、HTML5 <legend> 标签

HTML5 <li> 标签 实例 HTML5 <li>标签用于表示文档中列表的项目&#xff0c;在下述例子中&#xff0c;我们分别在有序列表和无序列表中使用了<li>标签。 HTML 两个列表实例&#xff1a; 一个有序列表 (<ol>) 和 一个无序列表 (<ul>) : <ol…

机器学习入门实例-加州房价预测-2(数据整理)

计算相关性 使用corr()计算standard correlation coefficient&#xff08;Pearson’s r&#xff09;。矩阵不是很方便观察&#xff0c;可以直接排序median_house_value列&#xff0c;可以看出median_house_value与median_income的相关性挺大的。 corr_matrix visual_data.cor…