压缩文法的等价变换
变化压缩算法
变化压缩算法
变化压缩算法(Delta Compression Algorithm)是一种用于压缩数据的技术,它通过比较原始数据和其后续版本之间的差异(变化),然后仅保存这些变化,从而减少存储或传输数据的量。
常见的变化压缩算法包括:
1. 差分压缩(Differential Compression):差分压缩算法通过比较相邻版本的数据,找出它们之间的差异,并只保存这些差异。
当需要恢复数据时,可以根据原始数据和差异数据来还原出后续版本的数据。
2. 增量压缩(Incremental Compression):增量压缩算法是一种特殊的差分压缩算法,它在保存差异数据的同时,还保存了原始数据和之前版本的差异数据。
这样,当需要恢复数据时,只需依次应用各个增量数据即可。
3. 补丁压缩(Patch Compression):补丁压缩算法将两个版本之间的差异保存为一个补丁文件,当需要升级或更新软件时,可以通过应用这个补丁文件来快速将旧版本升级为新版本。
这些变化压缩算法广泛应用于软件更新、版本管理、备份和复制等场景,可以有效减少数据传输和存储的成本,提高数据的利用效率。
通过使用变化压缩算法,用户可以节省带宽和存储空间,并加快数据传输和处理速度。
编译原理实验二:压缩文法的等价变换
实验二:压缩文法的等价变换一:要求输入:任意的上下文无关文法输出:等价的压缩了的文法要求:除了可查看压缩了的文法,还可查看删除了哪些规则二:实验目的了解文法的简化三:实验原理删除文法中的有害规则和多余规则有害规则:若文法中有如U::=U的规则,则这就是有害规则,它会引起二义性,而无任何用处。
多余规则:(1)某条规则U::=u的左部非终结符U(U不是识别符号),不在任何其他规则右部出现,即所有的推导始终不会用到此规则。
【不可到达】(2)在推导句子的过程中,一旦使用了该规则,将推不出任何终结符号串。
即该规则中含有推不出任何终结符号串的非终结符。
【不可终止】四:数据结构与算法struct Chomsky{string left;string right;};void apart(Chomsky *p,int i) //分开产生式左右部void VNVT(Chomsky *p)//求VN和VTint zero(Chomsky *p)//0型文法int one(Chomsky *p)//1型文法int two(Chomsky *p)//2型文法void shanchu(Chomsky *p)//删除多余规则与有害规则五:出错分析1:变量重复定义导致了一些小错误2:程序太长{}缺少也导致了错误3:后面删除规则的程序出错了,没有调试成功。
六:实验结果与分析不是上下文无关文法的:2型文法的压缩:七:源代码#include<iostream>#include<string>using namespace std;#define max 50int NONE=1;int RELEFT=1;string strings,noend,end;//非终结符与终结符存储int n;//产生式总数int flag;struct Chomsky{string left;string right;};void apart(Chomsky *p,int i) //分开产生式左右部{int j;for(j=0;j<strings.length();j++)if(strings[j]=='-'){p[i].left=strings.substr(0,j);p[i].right=strings.substr(j+1,strings.length()-j);}}void VNVT(Chomsky *p)//求VN和VT{int i,j;for(i=0;i<n;i++){for(j=0;j<(int)p[i].left.length();j++){if((p[i].left[j]>='A'&&p[i].left[j]<='Z'))//非终结符判断{if(noend.find(p[i].left[j])>100)noend+=p[i].left[j];}else{if(end.find(p[i].left[j])>100)end+=p[i].left[j];}}{if(!(p[i].right[j]>='A'&&p[i].right[j]<='Z'))//终结符判断{if(end.find(p[i].right[j])>100)end+=p[i].right[j];}else{if(noend.find(p[i].right[j])>100)noend+=p[i].right[j];}}}}int zero(Chomsky *p)//0型文法{int flag(0),count(0);int i,j;for(i=0;i<n;i++){{if(p[i].left[j]>='A'&&p[i].left[j]<='Z') //有否非终结符flag++;}if(flag>0){flag=0;count++;}elsebreak; //左部没有非终结符,结束}if(count==n)return 1; //属于0型文法else{cout<<endl<<"所输产生式不属于任何文法。
ZIP算法详解(转!)
ZIP算法详解(转!)zip 的压缩原理与实现(lz77 算法压缩)⽆损数据压缩是⼀件奇妙的事情,想⼀想,⼀串任意的数据能够根据⼀定的规则转换成只有原来 1/2 - 1/5 长度的数据,并且能够按照相应的规则还原到原来的样⼦,听起来真是很酷。
半年前,苦熬过初学 vc 时那段艰难的学习曲线的我,对 MFC、SDK 开始失望和不满,这些虽然不算易学,但和 DHTML 没有实质上的区别,都是调⽤微软提供的各种各样的函数,不需要你⾃⼰去创建⼀个窗⼝,多线程编程时,也不需要你⾃⼰去分配 CPU 时间。
我也做过驱动,同样,有DDK(微软驱动开发包),当然,也有 DDK 的“参考⼿册”,连⼀个最简单的数据结构都不需要你⾃⼰做,⼀切都是函数、函数……微软的⾼级程序员编写了函数让我们这些搞应⽤的去调⽤,我不想在这⾥贬低搞应⽤的⼈,正是这些应⽤⼯程师连接起了科学和社会之间的桥梁,将来可以做销售,做管理,⽤⾃⼰逐渐积累起来的智慧和经验在社会上打拼。
但是,在技术上来说,诚实地说,这并不⾼深,不是吗?第⼀流的公司如微软、Sybase、Oracle 等总是⾯向社会⼤众的,这样才能有巨⼤的市场。
但是他们往往也是站在社会的最顶层的:操作系统、编译器、数据库都值得⼀代代的专家去不断研究。
这些帝国般的企业之所以伟⼤,恐怕不是“有经验”、“能吃苦”这些中国特⾊的概念所能涵盖的,艰深的技术体系、现代的管理哲学、强⼤的市场能⼒都是缺⼀不可的吧。
我们既然有志于技术,并且正在起步阶段,何必急不可耐地要转去做“管理”,做“青年才俊”,那些所谓的“成功⼈⼠”的根底能有⼏何,这样⼦浮躁,胸中的规模和格局能有多⼤?在我发现vc只是⼀个⽤途⼴泛的编程⼯具,并不能代表“知识”、“技术”的时候,我有些失落,⽆所不能的不是我,⽽是 MFC、SDK、DDK,是微软的⼯程师,他们做的,正是我想做的,或者说,我也想成为那种层次的⼈,现在我知道了,他们是专家,但这不会是⼀个梦,有⼀天我会做到的,为什么不能说出我的想法呢。
压缩算法 原理
压缩算法原理压缩算法是一种用来减少数据量的技术,以便在存储或传输数据时节省空间或带宽。
这种算法通过使用各种方法来识别和消除数据中的冗余,以及使用更简洁的编码来表示重复出现的模式或符号。
有两种主要类型的压缩算法:无损压缩和有损压缩。
1. 无损压缩:无损压缩算法通过识别和消除数据中的冗余来减少数据量,但在解压缩过程中能够完全恢复原始数据。
常见的无损压缩算法包括:- 哈夫曼编码:根据数据中出现的频率来分配更短的编码给出现频率高的符号,从而减少整体数据量。
- 霍夫曼编码常结合字典压缩或字典匹配算法,通过将常见的符号映射到较短的编码,从而减少数据量。
- Lempel-Ziv-Welch (LZW) 算法:通过建立和利用字典来对输入数据进行编码和解码。
它将输入数据中出现的连续序列替换为向字典添加新条目的索引。
2. 有损压缩:与无损压缩不同,有损压缩算法通过牺牲一些数据的精度或质量来实现更高的压缩率。
这种压缩技术主要适用于对数据质量要求不高的场景,如音频、图像和视频。
常见的有损压缩算法包括:- JPEG:主要用于图像压缩,通过舍弃一部分高频细节并对颜色信息进行近似来减小文件大小。
- MP3:用于音频压缩,通过去除对人耳不可察觉的音频信号信息来减小文件大小。
- MPEG:用于视频压缩,将视频帧中相似的区域识别为运动对象并存储与相对帧的差异。
压缩算法的优劣取决于数据类型和需求。
无损压缩允许完全恢复原始数据,但压缩率较低。
有损压缩可以显著减小文件大小,但在解压缩后的数据上可能会有一定程度的信息丢失。
因此,在选择压缩算法时,需要根据具体情况权衡压缩率和数据质量。
数据压缩的历史原理和常用算法
数据压缩的历史原理和常用算法数据压缩是指通过使用特定的算法和技术,将原始数据转换为更紧凑的形式,从而减少存储空间或传输带宽的占用。
数据压缩在通信、存储和处理大规模数据时非常重要。
下面将介绍数据压缩的历史、原理和常用算法。
一、历史早期的数据压缩算法包括霍夫曼编码和LZW(Lempel-Ziv-Welch)编码。
这些算法基于数据中的统计特性,通过构建编码表将较常见的模式映射为较短的编码,从而实现数据压缩。
随着计算机技术的发展,诸如ZIP 和GZIP等通用的压缩算法被广泛采用。
二、原理压缩过程中,数据通过压缩算法转换为较紧凑的形式,并生成对应的压缩码。
压缩码可以是二进制序列、位图或其他形式。
解压缩过程中,压缩码被还原为原始数据。
1.无损压缩:无损压缩是指压缩和解压缩过程中不会丢失任何数据信息。
常用的无损压缩算法包括:-霍夫曼编码:霍夫曼编码基于字符出现的频率来构建编码表。
出现频率较高的字符使用较短的编码,出现频率较低的字符使用较长的编码。
-LZW编码:LZW编码是一种字典压缩算法,通过构建和更新编码表,将连续出现的字符序列映射为短的编码。
-预测编码:预测编码通过对数据进行预测和差值计算,将预测误差编码为较短的码字。
2.有损压缩:有损压缩是指在压缩和解压缩过程中会丢失一定的数据信息,但这些信息对于最终应用并不重要。
有损压缩广泛应用于音频、图像和视频等多媒体数据的压缩。
常用的有损压缩算法包括:-JPEG:JPEG是一种常用的图像压缩算法,通过采样、DCT变换和量化等步骤将图像转换为频域表示,并对高频信息进行丢弃。
-MP3:MP3是一种常用的音频压缩算法,通过对音频信号进行频域变换、量化和信号掩蔽等步骤,丢弃听觉上不敏感的信号。
三、常用算法数据压缩中常用的算法包括:1.ZIP:ZIP是一种常用的无损压缩算法,基于霍夫曼编码和LZW编码。
ZIP可以压缩多个文件和目录,并生成一个ZIP文件。
2. GZIP:GZIP是基于DEFLATE算法的压缩算法,用于压缩单个文件。
用某种高级程序设计语言实现文法的等价压缩算法(PASCAL语言实现)
编译原理实习作业用某种高级程序设计语言实现 文法的等价压缩算法(PASCAL语言实现)二○○一年十月一日实习作业:用高级程序设计语言实现对文法多余规则的等价压缩 一.相关定义及定理:给出一个无U::=U形规则的前提下规则不多余的判别条件:一个规则U::=u要是有用的,便得在推导中被应用,即其左部非终结符号U必须在句子的推导中出现,且u能推导到终结符号串。
为此,U与u必须分别满足下列条件:条件1:Z=>*xUy,其中x,y∈V,Z为识别符号;条件2:u=>+t,其中t∈VT 。
●判别条件1的加标记算法步骤如下:步骤1:对规则中识别符号Z加标记;步骤2:对左部非终结符加有标记的规则,将其右部中出现的一切非终结符号加标记;步骤3:检查是否一切非终结符号都已加过标记。
是,则无多余规则而结束;否,则执行下一步骤;步骤4:检查最近一次执行步骤2时是否未对任何非终结符号加过标记。
如果是这样,该文法中左部非终结符号未加过标记的规则都不满足条件1,这些规则是多余的,结束。
否则重复步骤2。
●判别条件2的加标记算法步骤如下:步骤1:对u∈V的规则U::=u之左部非终结符号U加标记;步骤2:对右部仅包含终结符号与已加标记的非终结符号的规则之左部加标记;步骤3:检查是否已对一切非终结符号加过标记。
是,则无多余的规则而结束;否,则执行下一步骤;步骤4:检查最近一次执行步骤2时是否未对任何非终结符号加过标记。
如果是这样,该文法中左部非终结符号未加过标记的规则都不满足条件2,这些规则是多余的,结束。
否则重复步骤2。
概括起来,对一个给定的文法进行压缩文法等价变换的规范步骤如下:●展开文法规则,并删除U::=u形规则●判别条件1和2,执行加标记算法●删除不满足条件的无用规则,得到等价的压缩了的文法。
二.PASCAL程序设计语言实现文法压缩算法的功能说明:●文法的存储:对每一个可能包含无用规则的文法G[Z]以数组(grammar类型)形式存储。
压缩算法原理范文
压缩算法原理范文压缩算法是一种将文件或数据转换成更小、更紧凑的形式,以便更高效地存储和传输的技术。
它可以大大减少存储空间和传输带宽的需求,并且可以在不损失太多数据精度的情况下还原原始数据。
压缩算法的原理有多种,下面将介绍几种常见的压缩算法原理。
1.无损压缩算法:无损压缩算法是一种能够还原原始数据的压缩算法。
其原理包括以下几个步骤:-字典生成:该步骤根据待压缩数据中的规律,根据其中一种规则生成字典,字典中存储了一些重复的模式。
这些重复的模式可以通过索引来表示,从而减小了存储的大小。
-数据替换:根据生成的字典,对原始数据进行替换或者重新编码,以减少存储空间。
替换后的数据可以使用更小的编码表示,从而减少存储空间。
- 压缩:将替换或者重新编码后的数据进行压缩,使用一些压缩算法,如Huffman编码、Lempel-Ziv编码等等,将数据进一步压缩。
-解压缩:对压缩后的数据进行解压缩,还原原始数据。
解压缩过程就是压缩的逆过程,通过还原字典与解码规则,将压缩后的数据恢复成原始数据。
2.有损压缩算法:有损压缩算法是一种在压缩过程中牺牲一定数据精度以换取更高压缩率的算法。
具体原理如下:-数据分析:首先对原始数据进行分析,找出数据中的冗余或不重要的信息。
-数据转换:通过使用数学或统计学的方法,将原始数据转换为一种新的表示形式。
这种表示形式可以利用原始数据的统计特性,将高频或重复的数据转换为更简洁的形式。
-量化:对转换的数据进行量化,将其分为级别或范围。
这个过程可以减少数据的精确度,从而降低存储空间和传输带宽的需求。
-压缩:使用一些数学模型和编码技术,对量化后的数据进行压缩。
通常使用的有损压缩算法包括小波压缩、离散余弦变换等。
-解压缩:对压缩后的数据进行解压缩,还原原始数据。
由于该算法是有损压缩,所以还原后的数据与原始数据不完全一样,会存在一定的误差。
压缩算法主要的原理就是通过去除冗余信息、利用数据的统计特性、数据的转换和量化等技术手段,将原始数据进行编码和压缩,从而实现减小存储空间和传输带宽的目的。
用于消除语法分析冲突的yacc文法变换模式
⽤于消除语法分析冲突的yacc⽂法变换模式⽤于消除语法分析冲突的YACC⽂法变换模式摘要:YACC是Unix/Linux上⼀个⽤来⽣成编译器的编译器(编译器代码⽣成器)。
YACC⽣成的编译器主要是⽤C语⾔写成的语法解析器(Parser),需要与词法解析器Lex⼀起使⽤,再把两部份产⽣出来的C程序⼀并编译。
YACC本来只在Unix系统上才有,但现时已普遍移植往Windows及其他平台。
本⽂分析了使⽤LAI R(1)分析程序⽣成系统YACC时经常遇到的语法分析冲突问题及消除语法。
分析冲突的策略,总结了⼀组⽂法变换模式,利⽤这些模式可以有效地解决语法分析冲突阉题。
关键词: YACC 语法分析冲突⽂法变换模式引⾔YACC(Yet Another Compiler Compiler)是美国贝尔实验室著名的编译程序⽣成系统,⽤于开发以字符流输⼊的,语法制导的软件,如计算机语⾔的编(翻)译程序、解释程序、程序理解和⽩盒测试⼯具、语法制导的编辑器等近年来许多利⽤YACC的开发⼯作均指出了消除语法分析冲突的困难性,如开发C/C++程序理解⼯具的前端_2 J、Fortran95⾄C++的翻译程序、测试及测试控制标记语⾔TTCN-3的语法分析程序L4 J、硬件描述语⾔VHDL的分析程序等.本⽂借鉴软件设计模式的研究⽅法,总结出7个⽤于消除语法分析冲突的⽂法变换模式.下⾯介绍⽂中⽤到的⼏个基本概念和有关约定.⼀、概念和约定在本⽂中,术语“YACC”代表采⽤u也R(1)分析⽅法的⼀⼤类语法分析程序⽣成系统,包括贝尔实验室的YACC[“、⾃由软件基⾦会(GNU)的BiSo⼀6 J 及它们的所有变体,⼄虬R(1)分析⽅法属于移进归约分析⽅法.所谓移进,是指分析栈中移⼈新的终结符号归约是指⽤⼀条产⽣式的左部符号替换若⼲个栈顶符号,出栈符号的数⽬取决于产⽣式右部的长度.⽂法的LALR(1)分析表记录了当分析器的状态为s,当前⾯临的输⼊符号为t时应该执⾏的分析动作如果分析表的⼀个⼈⼝中记录了两个不同的分析动作,则称该⽂法包含⼀个语法分析突.分析冲突有两种:移进⼀归约冲突和归约⼀归约冲突,⼀个⽂法是LALR(1)⽂法,当且仅当它的LAI R(1)分析表中不含语法分析冲突.“UR(1)⽂法属于⽆歧义的上下⽂⽆关⽂法⼦类.若⼀个⽂法是歧义的。
数据压缩算法原理
数据压缩算法原理1.无损压缩算法:无损压缩算法是一种压缩数据的方法,它保留了原始数据的全部信息,且在解压后可以完全恢复原始数据。
无损压缩算法的核心原理是通过编码和替代方法来减少数据的冗余信息。
其中最常见的无损压缩算法是霍夫曼编码和算术编码。
-霍夫曼编码:霍夫曼编码是一种变长编码,它给出了将频率较高的字符用较短的编码表示,频率较低的字符用较长的编码表示的方式。
它的基本原理是通过根据字符的频率构建一个最小堆树,并将频率低的字符放在较深的位置,频率高的字符放在较浅的位置,以减少编码长度。
-算术编码:算术编码是一种将序列映射为一个小数的编码方法。
它的基本原理是根据不同字符出现的概率将序列划分为不同长度的区间,并将编码映射到相应的区间。
通过不断迭代这个过程,可以将整个序列压缩到一个小数中。
2.有损压缩算法:有损压缩算法是一种在压缩数据时丢失一定量的信息以降低数据的质量的方法。
与无损压缩算法不同,有损压缩算法在解压后的数据中无法100%恢复原始数据。
有损压缩算法广泛应用于音频、视频等多媒体数据的压缩中。
-基于变换的方法:基于变换的有损压缩算法的核心原理是将数据从时域转换到频域,利用频域表示的特性来进行数据压缩。
常见的基于变换的方法有离散余弦变换(DCT)和离散傅里叶变换(DFT)。
它们可以通过分解源数据为不同频率分量对数据进行压缩。
-基于预测的方法:基于预测的有损压缩算法的核心原理是通过对数据的前后关系进行建模,预测当前数据的值,并将预测误差进行压缩。
常见的基于预测的方法有差分编码和运动补偿。
3.字典压缩算法:字典压缩算法是一种基于字典的数据压缩方法,它利用了数据中的潜在重复子串来进行压缩。
字典压缩算法的核心原理是将源数据分割为不同的字典项,并使用索引来替代重复的字典项。
最常见的字典压缩算法是LZ77和LZW算法。
-LZ77算法:LZ77算法是一种实时的字典压缩算法,它通过使用窗口缓冲区来存储之前遇到的数据。
《编译原理》教学大纲
《编译原理》教学大纲大纲说明课程代码: 3225003总学时: 64 学时(讲课 48 学时,实验16 学时)总学分: 4课程类别:学科基础课适用专业 : 计算机科学与技术(专业)预修要求: C 语言程序设计、 C++ 程序设计、数据结构课程的性质、任务及地位:《编译原理》是计算机科学与技术专业的一门重要基础课。
通过对该课程的学习,使学生掌握编译过程中的相关原理和编译技术,让学生能初步进行编译程序的开发和维护,同时促进提高学生开发软件的能力。
教学目的与基本要求:本课程的目的,通过向学生讲述编译系统的结构、工作流程及编译程序各部分的设计原理和实现技术,使学生既掌握编译技术理论的基础与基本知识,也具有设计、实现、分析和维护编译程序等方面的初步能力。
本课程理论性较强。
因授课对象为工科学生,所以在强调编译系统的构造原理和实现方法的同时,为培养学生的实际工作能力,通过上机实践进一步加深学生对课堂教学内容的理解。
目的是要使学生牢固掌握相关的基本理论和基本方法,并能初步利用上述理论和方法解决简单实际问题。
教学方法和教学手段的建议:在教学方法上,贯彻理论联系实际、“精讲、多练”的原则,进行案例式、启发式的教学,对于一些实际性较强的问题要多采用课堂讨论等方式,以提高学生的思辨能力和学习的主动性;引导学生读书、理解、体悟、运用相结合;提高学生的学习兴趣与热情,培养与发挥学生的提出、分析及解决问题的能力。
教学手段:运用多媒体教学手段 +黑板 +上机实验的手段。
采取课堂讲授、课堂讨论、课后练习与自学等形式。
大纲的使用说明:大纲对课程性质、目的等作简单说明,同时列出各章节要学习的知识点、重点、难点,便于教学时教授重点的安排和学生自学安排。
大纲正文第一章引论学时: 4 学时(讲课 4 学时,实验 0 学时)了解编译的概念;理解编译程序的各组成部分及功能。
本章讲授要点:介绍程序设计语言与编译程序间的关系,主要内容包括:各级程序设计语言的定义、源程序的执行、编译程序的构造、编译程序的分类、形式语言理论与编译实现技术的联系。
文法的等价性的名词解释
文法的等价性的名词解释文法的等价性是指在语言学中,如果两种文法可以生成相同的语言,那么它们就是等价的。
在深入探讨文法的等价性之前,我们首先需要了解一些基本概念:文法、语言和生成。
然后,我们将介绍文法的等价性的概念以及与之相关的一些重要问题。
一、文法、语言和生成文法是描述一种语言结构的规则集合。
它由终结符号、非终结符号和产生规则组成。
终结符号是语言中的最基本单位,代表了具体的词汇。
非终结符号则表示了某种语言规则或语法结构。
产生规则描述了如何将非终结符号替换为终结符号和非终结符号的规则。
语言是由文法生成的符串的集合。
在一种语言中,每个符串都符合该语言的文法规则。
从一个非终结符号出发,通过不断地应用产生规则,可以生成不同的符串。
这个过程被称为生成。
二、文法的等价性文法的等价性是一个非常重要的概念。
在形式语言理论中,我们关注的是语言本身的性质,而不是语言的具体表示形式。
因此,如果两个文法可以生成相同的语言,它们就是等价的。
等价的文法可能具有不同的产生规则,但它们最终生成的符串是相同的。
这意味着,无论是使用哪个等价的文法,我们都可以得到相同的语言。
三、文法的等价性的问题文法的等价性涉及一些重要的问题,其中一些值得我们深入思考。
1. 文法的等价性是否是可判定的?在现实中,我们经常遇到需要判断两个文法是否等价的问题。
但是,判断文法的等价性是否总是可行的呢?这是一个复杂的问题,和图灵机问题类似。
虽然对于一些特定的文法类别,我们可以找到一些算法来判断等价性,但对于一般的文法类别来说,这个问题是无法判定的。
2. 如何证明两个文法是等价的?在实际应用中,我们有时需要证明给定的两个文法是等价的。
这个过程通常包括两个方面的工作:找到一个生成相同语言的等价文法,并证明这两个文法的等价性。
寻找等价文法的过程涉及使用一系列转换规则来修改文法的产生规则,以使得两个文法具有相同的生成能力。
证明等价性的过程则需要严格的逻辑推理,通常采用归纳法或形式化证明。
压缩文法的等价变换
}
}
public static void main(String args[])
{
test1 app=new test1();
}
}//class gramemer
实验结果:(java)
import java.util.Vector;
import javax.swing.JOptionPane;
public class test1
{
public class End
{
Vector<String> end=new Vector<String>();
public void add()
{
JOptionPane.showMessageDialog(null,"是3型文法");
return;
}
if(produce.is2(noend))
{
JOptionPane.showMessageDialog(null,"是2型文法");
return;
}
if(produce.is1())
{
JOptionPane.showMessageDialog(null,"是1型文法");
String s2=left.get(i);
System.out.println(s1);
System.out.println(s2);
if(noend.iscontain(s2))//如果左部是一个非终结符
{
if(end.isRGPcontain(s1))//正则表达式判断终结符是否包含s1 A->a型
if(end.contains(s))
编译原理讲义(第二章文法与语言)
语言的定义(短语,简单短语)
• 短语:对于文法G[Z],如果Z =>* xUy, U=>+ u。显然,w=xuy是一个句型。我 们称u是句型w中相对于U的短语。 • 简单短语:在上面的定义中,如果U ::= u是G的一个规则,那么,u是句型w中相 对于U的简单短语。 • 例子:P22页例2.13。
语言的定义(短语,句柄)
• 注意:在寻找一个句型的短语(或简单 短语)时,必须要求将这个短语规约为 相应的非终结符号后所得到的符号串仍 然是句型。 • 句柄:一个句型的最左简单短语称为该 句型的句柄。 • 定义句柄的原因:在自底向上识别一个 符号串时,总是规约这个句柄。
语言的定义(文法的语言)
• 文法的语言:一个文法G[Z]的语言,用 L(G[Z])表示,定义如下: L(G[Z]) = {x | Z=>* x 并且 x VT+} • 一个文法的语言就是该文法的所有的句子的 集合。 • 文法的语言是所有终结符号串所组成的集合 的子集,一般是真子集。
• 定理2.7 对于CFG,如果存在句型 x=x1x2…xn且x=>*y,必然存在y1,y2,…,yn 使得: xi=>*yi且y= y1y2…yn。 • 定理2.8 如果:x=>*y,如果x的首符号是 终结符号,则y的首符号也是终结符号; 反之,如果y的首符号是非终结符号,那 么x的首符号也是非终结符号。
形式语言与程序设计语言
• 虽然程序设计语言的语法都使用上下文 无关文法来描述,但是通常语言都是上 下文相关的。 • 使用上下文无关文法描述语言的原因是: 存在高效处理上下文无关文法的技术。
关于CFG的进一步讨论
• Chomsky范式:所有的上下文无关语言 都可以用如下形式的文法产生:所有的 规则都形如:U ::= VW 或者 U::=T,其 中U,V,W为非终结符号,T为终结符号。 • Greibach范式:所有上下文无关语言都能 由这样的文法产生:U::=Tu,这里U为非 终结符号,T为终结符号。
c++ 实现的压缩算法
C++实现的压缩算法有很多种,这些算法根据不同的使用场景和需求,可以分为无损压缩算法和有损压缩算法。
下面我将列举几种常见的无损压缩算法,并简单描述其原理和特点:1. Huffman编码(Huffman Coding)Huffman编码是一种基于字符频率来构造最优前缀码的压缩算法。
它通过构建一个Huffman树来为每个字符分配不等长的位序列,频率高的字符使用较短的编码,频率低的字符使用较长的编码,从而达到压缩数据的目的。
2. LZ77和LZ78算法LZ77和LZ78是由Lempel和Ziv在1977年和1978年提出的两种压缩算法。
它们都是基于字典的压缩技术,通过查找重复的字符串并用较短的引用来替代,以此来实现数据的压缩。
3. Deflate算法Deflate算法结合了LZ77算法和Huffman编码。
它首先使用LZ77算法进行字符串替换以消除重复的数据,然后对结果进行Huffman编码。
Deflate算法被广泛应用于gzip 和PNG图像格式。
4. Zstandard(Zstd)Zstandard是一个由Facebook开发的现代压缩算法,它提供了很高的压缩比和速度。
Zstd结合了多种已知的压缩技术,并加入了一些新颖的方法来提高性能。
5. BrotliBrotli是由Google开发的压缩算法,它同样结合了多种技术,包括LZ77、Huffman 编码和二阶文法变换(2nd order context modeling)。
Brotli旨在提供更高的压缩比,特别是在Web内容的压缩上。
以下是一个简单的C++程序,演示了如何使用zlib库(实现了Deflate算法)来压缩和解压缩字符串:```cpp#include <iostream>#include <vector>#include <cstring>#include <zlib.h>// 压缩函数std::vector<unsigned char> compress(const std::string& data) {z_stream zs; // zlib状态memset(&zs, 0, sizeof(zs));if (deflateInit(&zs, Z_BEST_COMPRESSION) != Z_OK)throw(std::runtime_error("deflateInit failed while compressing."));zs.next_in = reinterpret_cast<Bytef*>(const_cast<char*>(data.data()));zs.avail_in = data.size(); // 设置输入int ret;char outbuffer[32768];std::vector<unsigned char> outstring;// 压缩do {zs.next_out = reinterpret_cast<Bytef*>(outbuffer);zs.avail_out = sizeof(outbuffer);ret = deflate(&zs, Z_FINISH);if (outstring.size() < zs.total_out) {// 将缓冲区的数据添加到输出字符串中outstring.insert(outstring.end(), outbuffer, outbuffer + zs.total_out - outstring.size()); }} while (ret == Z_OK);deflateEnd(&zs);if (ret != Z_STREAM_END) { // 出错处理std::ostringstream oss;oss << "Exception during zlib compression: (" << ret << ") " << zs.msg;throw(std::runtime_error(oss.str()));}return outstring;}// 解压缩函数std::string decompress(const std::vector<unsigned char>& data) {z_stream zs; // zlib状态memset(&zs, 0, sizeof(zs));if (inflateInit(&zs) != Z_OK)throw(std::runtime_error("inflateInit failed while decompressing."));zs.next_in = const_cast<Bytef*>(data.data());zs.avail_in = data.size();int ret;char outbuffer[32768];std::string outstring;// 解压缩do {zs.next_out = reinterpret_cast<Bytef*>(outbuffer);zs.avail_out = sizeof(outbuffer);ret = inflate(&zs, 0);if (outstring.size() < zs.total_out) {outstring.append(outbuffer, zs.total_out - outstring.size());}} while (ret == Z_OK);inflateEnd(&zs);if (ret != Z_STREAM_END) { // 出错处理std::ostringstream oss;oss << "Exception during zlib decompression: (" << ret << ") " << zs.msg; throw(std::runtime_error(oss.str()));}return outstring;}int main() {std::string original_text = "This is the original text to be compressed and decompressed!"; std::vector<unsigned char> compressed_data = compress(original_text);std::string decompressed_text = decompress(compressed_data);std::cout << "Original: " << original_text << std::endl;std::cout << "Compressed size: " << compressed_data.size() << std::endl;std::cout << "Decompressed: " << decompressed_text << std::endl;return 0;}```请注意,为了使用上述代码,你需要在你的系统上安装zlib库,并在编译时链接zlib。
字符串压缩算法
字符串压缩算法字符串压缩算法是一种能够有效减少字符串大小的方法,可以被用于存储和传输字符串,以节省存储空间和传输带宽。
一、字符串压缩算法的原理字符串压缩算法主要是通过对字符串中相同字符序列进行替换,来节省字符串的大小。
首先,使用程序扫描一个字符串,当发现当前字符与前一个相同,就将其记录下来,并累积计数;当下一个字符发生变化时,才将计数结果与前一个字符一起替换原字符。
压缩后的字符串由两部分组成,一部分是非重复字符;另一部分是计数信息,表示前一个字符重复的次数。
以“aabbbccc”为例,压缩后的字符串就是“a2b3c3”。
从这个例子中可以看出,字符串的长度由7变成6,压缩了14.3%。
二、字符串压缩算法的应用1、文件压缩文件压缩是最常见的应用之一,可以最大限度地减少文件的存储空间,提高数据传输效率。
目前,主要使用的文件压缩算法有哈夫曼算法,LZW算法等,其中哈夫曼算法使用字符串压缩算法进行处理,针对重复出现的字符建立编码表,将多次出现的字符编码为短码,从而节省内存空间。
2、文本文件优化文本文件优化是另一种重要的字符串压缩算法应用,它的主要目的是减小文件的大小,提高文件的加载速度。
文本文件优化中,大多数算法是设计用于缩小文本文件大小的,例如HTML文件压缩、JavaScript文件压缩等。
因为HTML文件和JavaScript文件都包含很多不必要的空格和换行,这些空格和换行可以被删除,以节省文件大小。
三、字符串压缩算法的优缺点1、优点(1)字符串压缩算法可以有效减少字符串的长度,节省存储空间。
(2)字符串压缩算法可以减少文件的大小,从而提高文件的加载速度。
2、缺点(1)字符串压缩算法并不能完全替代传统的文件压缩方法,能够节省的空间不如文件压缩方法大。
(2)由于需要在压缩过程中扫描字符串,将需要一定的时间来完成整个压缩过程,会影响字符串的传输速度。
总之,字符串压缩算法是一种非常有效且常用的压缩方法,它可以用来减少字符串的长度,节省存储空间和提高文件的加载速度,是一种很有用的数据压缩方法。
博戈留波夫变换 压缩变换 等价
博戈留波夫变换压缩变换等价《博戈留波夫变换与压缩变换的等价性》1.引言在信号处理和数据压缩领域,博戈留波夫变换和压缩变换是两个重要且广泛应用的概念。
它们各自具有独特的特性和应用场景,但在某些情况下却可以等价转换。
本文将对博戈留波夫变换和压缩变换进行深入探讨,并重点研究它们之间的等价性。
2.博戈留波夫变换博戈留波夫变换是一种线性变换,常用于信号处理和数据压缩。
通过将信号在不同基函数下的投影系数进行变换,可以将信号在频域和空域之间进行转换,从而实现信号的压缩和重构。
博戈留波夫变换具有良好的频谱特性和能量集中特性,因此在减小数据量的同时能够保持信号的重要信息。
在实际应用中,博戈留波夫变换被广泛应用于图像压缩、语音信号处理等领域。
3.压缩变换压缩变换是一种通过改变数据表示方式来减小数据量的技术。
压缩变换能够从数据中提取出重要的特征,并且将数据表示为更加紧凑的形式。
这种方式能够在不损失信息的情况下大幅度减小数据量,从而在存储和传输方面具有显著的优势。
在数字图像处理和通信领域,压缩变换被广泛应用于降低数据传输成本和提高传输效率。
4.博戈留波夫变换与压缩变换的等价性在一些情况下,博戈留波夫变换和压缩变换是等价的。
具体来说,当信号的能量集中在低频部分时,博戈留波夫变换可以等价于压缩变换。
这是因为在这种情况下,博戈留波夫变换能够将信号的大部分能量集中表示为少量的基函数,从而实现了对信号的压缩。
当信号的能量主要集中在低频部分时,我们可以将博戈留波夫变换看作是一种压缩变换。
5.个人观点与理解在我看来,博戈留波夫变换与压缩变换的等价性提供了一种更加抽象和统一的视角来理解信号处理和数据压缩。
它告诉我们,在某些情况下不同的方法可以达到相同的效果,这启示我们可以在不同的领域和应用场景中借鉴不同的思想和方法。
了解等价性也有助于我们更加深入地理解博戈留波夫变换和压缩变换之间的联系,从而能够更加灵活地应用它们解决实际问题。
6.总结与回顾通过本文的探讨,我们深入了解了博戈留波夫变换和压缩变换这两个重要的概念,并研究了它们之间的等价性。
非ll1文法到ll1文法的等价变换代码
非LL(1)文法到LL(1)文法的等价变换是一种常见的语法转换方法,用于将不符合LL(1)文法规则的文法转换为符合LL(1)文法规则的文法。
在计算机科学和编译原理领域,LL(1)文法是一种重要的上下文无关文法,它具有很好的预测性和递归性,适合用于构建递归下降分析器和语法制导翻译。
对于不符合LL(1)文法规则的文法,需要进行等价变换,以便能够使用LL(1)分析方法进行语法分析和翻译。
在进行非LL(1)文法到LL(1)文法的等价变换时,通常需要进行以下步骤:1. 消除左递归2. 提取左因子3. 构造预测分析表消除左递归是为了消除文法中的左递归产生式,因为左递归会导致LL(1)分析器的死循环。
消除左递归的方法包括直接左递归消除和间接左递归消除,可以通过对文法进行变换和替换来实现。
消除左递归后,就可以进行下一步的处理。
提取左因子是为了消除文法中的左因子,因为左因子会导致LL(1)分析器的冲突。
提取左因子的方法包括将左因子提取为新的非终结符和产生式,以分离文法的产生式规则,从而避免冲突和歧义。
提取左因子后,就可以进行下一步的处理。
构造预测分析表是为了根据LL(1)文法的定义,构造出满足LL(1)分析表的预测分析表。
预测分析表是LL(1)文法分析器的核心数据结构,它包含了文法的所有终结符、非终结符和产生式规则,并用于进行分析和推导。
构造预测分析表的方法包括求出每个非终结符的FIRST集合和FOLLOW集合,然后根据这些集合来填写分析表。
构造预测分析表后,就可以使用LL(1)分析器对文法进行语法分析和翻译。
总结来看,非LL(1)文法到LL(1)文法的等价变换是一个重要且必要的过程,它可以将不符合LL(1)文法规则的文法转换为符合LL(1)文法规则的文法,从而能够使用LL(1)分析方法进行语法分析和翻译。
通过消除左递归、提取左因子和构造预测分析表等步骤,可以有效地实现非LL(1)文法到LL(1)文法的等价变换。
字符 压缩算法
字符压缩算法字符压缩算法是一种将字符序列转换为更短的表示形式的算法。
其目的是减少字符序列的存储空间以及传输时间。
字符压缩算法是数据压缩领域的一部分,常用于文件压缩、通信协议、数据库存储等领域。
下面将介绍一些常见的字符压缩算法。
一、Huffman编码Huffman编码是一种基于字符出现频率的编码算法。
它将出现频率较高的字符用较短的编码表示,而出现频率较低的字符用较长的编码表示。
这样可以达到字符压缩的效果。
Huffman编码的基本思想是通过构建一棵哈夫曼树来生成编码表。
首先统计字符的出现频率,然后根据频率构建哈夫曼树。
在哈夫曼树中,出现频率较高的字符位于树的较浅的位置,而出现频率较低的字符位于树的较深的位置。
接着根据哈夫曼树生成每个字符的编码,即出现在树的左子树路径上的字符分配编码“0”,出现在树的右子树路径上的字符分配编码“1”。
使用Huffman编码进行字符压缩时,只需将字符替换为对应的编码即可。
由于出现频率较高的字符编码较短,出现频率较低的字符编码较长,整个字符序列的存储空间可以大幅度减少。
二、Lempel-Ziv编码Lempel-Ziv编码是一种基于字典的编码算法。
它将连续出现的字符序列替换为短的编码。
该算法通过构建一个字典来存储已经出现的字符序列及其对应的编码。
Lempel-Ziv编码的基本思想是从字符序列的第一个字符开始,逐步向后扫描字符序列,如果扫描到的字符序列已经存在于字典中,则将该字符序列替换为对应的编码,然后继续扫描下一个字符;如果扫描到的字符序列不存在于字典中,则将该字符序列添加到字典中,并为该字符序列分配一个新的编码。
使用Lempel-Ziv编码进行字符压缩时,只需将字符序列中的连续出现的字符替换为对应的编码即可。
由于相同的字符序列可以反复出现,通过利用已经添加到字典中的字符串及其对应的编码,整个字符序列的存储空间可以得到较大减少。
三、Run-Length编码Run-Length编码是一种基于连续出现字符的编码算法。
压缩感知优化问题的等价表示及其目标罚函数方法
i n a n ME NG Z h i L e i I ANG M i n E N R u i - XU - J S q g y
( , , ) C o l l e e o f E c o n o m i c s a n d M a n a e m e n t Z h e i a n U n i v e r s i t o f T e c h n o l o H a n z h o u 3 1 0 0 2 3, C h i n a g g j g y g y g
第4 4卷 第6 A期 2 0 1 7年6月
计 算 机 科 学 C OMP UT E R C I E N C E S
V o l . 4 4N o . 6 A J u n e 2 0 1 7
压缩感知优化问题的等价表示及其目标罚函数方法
孟志青 徐蕾艳 蒋 敏 沈 瑞 ( ) 浙江工业大学经贸管理学院 杭州 3 1 0 0 2 3
, A b s t r a c t i r s t l t h e d e f i n i t i o n o f a n e u i v a l e n t r e r e s e n t a t i o n f o r c o m r e s s e d s e n s i n o t i m i z a t i o n w a s r o b l e m i v e n . F y q p p g p p g i s t h a t a n o t i m a l s o l u t i o n t o t h e e u i v a l e n t r e r e s e n t a t i o n i s a n o t i m a l s o l u t i o n t o c o m r e s s e d s e n I t r o v e d r o b l e m - p p q p p p p , , r o b l e m. T h e n e n a l t s i n a n o b e c t i v e f u n c t i o n w a s d e f i n e d w h i c h h a s m o r e t h a n 2o r d e r o f s m o o t h n e s s a n d i t s i t e r a - p p y g j , t i v e a l o r i t h m w a s i v e n . T h e c o n v e r e n c e o f t h e a l o r i t h m w a s r o v e d . B s o l v i n t h e o b e c t i v e e n a l t f u n c t i o n t h e g g g g p y g j p y r o b l e m r o v i d e s a r o x i m a t e o t i m a l s o l u t i o n o f c o m r e s s e d s e n s i n o t i m i z a t i o n c a n b e o b t a i n e d . T h i s m e t h o d a n e w p p p p p p g p t o o l f o r u s t o s t u d a n d s o l v e t h e a c t u a l c o m r e s s e d s e n s i n . y p g , , , e n a l t K e w o r d s o m r e s s i v e s e n s i n E u i v a l e n t r e r e s e n t a t i o n S a r s e o t i m i z a t i o n O b e c t f u n c t i o n C p y p g q p p p j y 找更好的求解方法 。 为 此 , 本文提出了一种压缩感知0模问 题的新表示 , 它等价于 0 模问题 , 同时提出了一种目标罚 函 数 方法来求解这种新的问题 。 罚函数是求解约束 优 化 的 一 种 重 要 方 法 , 它是将约束优 化问题转化成无约束优化题的方法, 对于简化约束优化问题 起到关键作用 。 其由于使用简单 、 便于掌握 , 受到许多工 程 优 化研究者和应用 者 的 青 睐 。 压 缩 感 知 的 p 模 问 题 的 正 则 化 表示本质上可以看做是一种 精 确 罚 函 数 的 形 式 。 罚 函 数 有 2 次、 低阶 、 精确等多种形式, M e n 0 1 3年发展了一种新 g等于 2
二元等价变换
二元等价变换二元等价变换引言二元等价是一个数学概念,用来描述两个二进制数字序列之间的相互转换关系。
在计算机科学和信息理论领域,二元等价变换被广泛应用于数据压缩、数据编码和信息安全等方面。
本文将介绍二元等价变换的基本概念,相关的算法和应用。
一、基本概念 1.1 二进制数字序列二进制数字序列是由0和1组成的数字序列。
它是最基本的数字表示方式,在计算机中常用于表示数据和信息。
1.2 二元等价在二进制数字序列中,两个序列被称为二元等价,当且仅当它们可以通过一系列的等价变换相互转换。
1.3 等价变换等价变换是指将一个二进制数字序列转换成另一个等价的二进制数字序列的操作。
等价变换可以包括插入、删除、替换、交换等多种操作。
二、二元等价变换的算法 2.1 汉明距离汉明距离是一个度量两个等长字符串之间的差异度量。
它定义为将一个字符串改变为另一个字符串所需要的最小操作次数,其中操作包括插入、删除和替换。
汉明距离可以作为判定两个二进制数字序列是否等价的度量指标。
2.2 哈希函数哈希函数是一个可以将任意大小的数据映射为固定大小的值的函数。
在二元等价变换中,哈希函数可以用于将一个二进制数字序列转换成一个唯一的哈希值,从而实现等价变换。
2.3 压缩算法压缩算法是一种将数据转换成更紧凑表示形式的算法。
在二元等价变换中,可以使用压缩算法将一个二进制数字序列转换成一个更短的二进制序列,并通过解压算法实现等价变换。
三、二元等价变换的应用 3.1 数据压缩二元等价变换可以用于数据压缩,将原始数据转换成更紧凑的表示形式,从而减小存储空间的占用和数据传输的带宽消耗。
3.2 数据编码在信息传输和存储中,二元等价变换可以用于数据编码。
通过等价变换,可以将原始数据转换成编码后的数据,使其更易于传输和处理。
3.3 信息安全二元等价变换在信息安全领域也有广泛的应用。
通过等价变换,可以将原始数据转换成不可逆的形式,提高数据的安全性和保密性。
四、总结二元等价变换是一个重要的数学概念,可以用于描述和实现二进制数字序列之间的相互转换关系。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
System.out.println("*"+ss[0]+"*");
System.out.println("*"+ss[1]+"*");
left.add(ss[0]);
right.add(ss[1]);
}
}//add()
public boolean is1()
Vector<String> right=new Vector<String>();//生产式的右部
public void add()
{ while(true)
{
String s=JOptionPane.showInputDialog(null,"请输入产生式空格隔开");
if(s==null)
return;
return true;
}//is1
public boolean is2(Noend noend)
{
int length=left.size();
for(int i=0;i<length;i++)
{
String s1=right.get(i);
String s2=left.get(i);
if(noend.iscontain(s2))
if(s==null)
return;
noend.add(s);
}
}//addendelement()
public boolean isRGPcontain(String s)//正则表达式判断s1是否在END的壁报里面正则忘了怎么写了
{
int length=s.length();
for(int i=0;i<length;i++)
实验结果:(java)
import java.util.Vector;
import javax.swing.JOptionPane;
public class test1
{
public class End
{
Vector<String> end=new Vector<String>();
public void add()
return;
}
}
public static void main(String args[])
{
test1 app=new test1();
}
}//class gramemer
}//is3
}//calss produce
public test1()
{
End end=new End();
Noend noend= new Noend();
Produce produce=new Produce();
end.add();
noend.add();
produce.add();
if(produce.is3(noend,end))
if(end.isRGPcontain(left1)&&noend.isRGPcontain(right1))
{System.out.println("A-aB型");continue;}
else return false;
}//if
else
return false;
}//for
return true;
if(end.contains(s))
return true;
else return false;
}// iscontain()
public boolean isRGPcontain(String s)//正则表达式判断s1是否在END的壁报里面正则忘了怎么写了
{
int length=s.length();
continue;
return false;
}//for
return true;
}//is2
public boolean is3(Noend noend,End end)
{
int length=left.size();
for(int i=0;i<length;i++)
{
String s1=right.get(i);
{
char a=s.charAt(i);
if(noend.contains(a))
continue;
else return false;
}//for
return true;
}
}//class noend
public class Produce
{
Vector<String> left=new Vector<String>();//生产式的左部
{
int length=left.size();
for(int i=0;i<length;i++)
{
String s1=right.get(i);
String s2=left.get(i);
if(s1.length()>=s2.length())
continue;
else
return false;
}//for
public boolean iscontain(String s)
{
if(noend.contains(s))
return true;
else return false;
}
public void add()
{
while(true)
{
String s=JOptionPane.showInputDialog(null,"请输入非终结符");
String s2=left.get(i);
System.out.println(s1);
System.out.println(s2);
if(noend.iscontain(s2))//如果左部是一个非终结符
{
if(end.isRGPcontain(s1))//正则表达式判断终结符是否包含s1 A->a型
实验原理:
所谓有害规则,是指形为U→U的产生式,它对描述语言显然是没有必要的。
所谓多余规则,有两种情况:一种非终结符不在任何产生式右端,这样该产生式无法用到,成为不可到达的。另一种是从某个非终结符无法推出终结符号,称为不可终止的。
实验算法:
有害规则非常好判断,只需判断箭头左右两个字符串是否相等。(注:其实在上下文无关文法中,箭头左边只有一个非终结符,在程序里把它看成字符串而不是单个字符是因为可以直接使用C++语言里的字符串比较函数来判断,省得增加麻烦。)
for(int i=0;i<length;i++)
{
String a=""+s.charAt(i);
if(end.contains(a))
continue;
else return false;
}//for
return true;
}
}//class end
public class Noend
{
Vector<String> noend=new Vector<String>();
{System.out.println("A->a型");continue;}
int s1length=s1.length();
String left1=s1.substring(0,s1length-2);//A-aB型中的a
String right1=""+s1.charAt(s1length-1);//A-aB型中的B
判断不可到达时,将所有产生式右边的非终结符收集起来放进一个数组,再判断左边是否有不含在该数组的非终结符(开始符号S除外),若有,则为不可到达的。
判断不可终止时,先假定所有非终结符都是不可终止的,再扫描所有产生式,若产生式右边不含左边的非终结符,则修改假定为可终止的。
将所有有害规则放在一个数组中,所有不可到达规则放在一个数组中,所有不可终止规则放在一个数组中,最后按实验要求分类列出这些要删除的规则。压缩后的规则从原规则中减去这些规则产生。
{
while(true)
{
String s=JOptionPane.showInputDialog(null,"请输入终结符");
if(s==null)
{break;
}//if
end.add(s);
}//while
}//add()
public boolean iscontain(String s)
{
{
JOptionPane.showMessageDialog(null,"是3型文法");
return;
}
if(produce.is2(noend))
{
JOptionPane.showMessageDialog(null,"是2型文法");
return;
}
if(produce.is1())
{
JOptionPane.showMessageDialog(null,"是1型文法");
课 程 名 称:压缩文法的等价转换
年级/专业/班:11级计算机类(二)班
姓 名:徐勇兵
学 号:E01114278
压缩文法的等价变换