压缩文法的等价变换.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
压缩文法的等价变换

课 程 名 称: 压缩文法的等价转换 实验目的: 了解有关文法的实用限制 实现用计算机判断有害规则和多余规则。 要求: 输入:任意的上下文无关文法 输出:等价的压缩了的文法 实验原理: 有害规则,是指形为U→U的产生式,它对描述语言显然是没有必要的。 多余规则,有两种情况:一种非终结符不在任何产生式右端,这样该产生式无法用到,成为不可到达的。另一是从某个非终结符无法推出,为不终止的。 算法: 非常好判断,只需判断箭头左右两个字符串是否相等。(:其实在上下文无关文法中,箭头左边只有一个非终结符,在程序里把它看成字符串而不是单个字符是因为可以直接使用C++语言里的字符串比较函数来判断,省得增加麻烦) 不可到达时,将所有产生式右边的非终结符收集起来一个数组,再判断左边是否有不含在的非终结符(开始符号S),若有,则为不可到达的。 不可终止时,先假定所有都是不可终止的,再扫描所有产生式,若产生右边不含左边的非终结符,则修改假定为可终止的。 所有有害规则放在一个数组中,所有不可到达规则放在一个数组中,所有不可终止规则放在一个数组中,按实验要求列出要删除的规则压缩的规则从原规则中减去这些规则产生。 结果: import java.util.Vector; import javax.swing.JOptionPane; public class test1 { public class End { VectorString end=new VectorString(); public void add() { while(true) { String s=JOptionPane.showInputDialog(null,请输入终结符 ); if(s==null) { break; }//if end.add(s); }//while }//add() public boolean iscontain(String s) { if(end.contains(s)) return true; else return false; }// iscontain() public boolean isRGPcontain(String s)//正则表达式判断s1是否在END的壁报里面 正则忘了怎么写了 { int length=s.length(); for(int i=0;ilength;i++) { String a=+s.charAt(i); if(end.contains(a)) continue; else return false; }//for return true; } }//class end public class Noend { VectorString noend=new VectorString(); public boolean iscontain(String s) { if(noend.contains(s)) return true; else return false; } public void add() { while(true) { String s=JOptionPane.showInputDialog(null,请输入非终结符 ); if(s==null) return; noend.add(s); } }//addendelement() public boolean isRGPcontain(String s)//正则表达式判断s1是否在END的壁报里面 正则忘了怎么写了 { int length=s.length(); for(int i=0;ilength;i++) { char a=s.charAt(i); if(noend.contains(a)) continue; else return false; }//for return true; } }//class noend public class Produce { VectorString left=

文档评论(0)

2017ll + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档