PAGE
PAGE 10
实验二:压缩文法的等价变换
一:要求
输入:任意的上下文无关文法
输出:等价的压缩了的文法
要求:除了可查看压缩了的文法,还可查看删除了哪些规则
二:实验目的
了解文法的简化
三:实验原理
删除文法中的有害规则和多余规则
有害规则:
若文法中有如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和VT
int zero(Chomsky *p)//0型文法
int one(Chomsky *p)//1型文法
int two(Chomsky *p)//2型文法
void shanchu(Chomsky *p)//删除多余规则与有害规则
五:出错分析
1:变量重复定义导致了一些小错误
2:程序太长{}缺少也导致了错误
3:后面删除规则的程序出错了,没有调试成功。
六:实验结果与分析
不是上下文无关文法的:
2型文法的压缩:
七:源代码
#includeiostream
#includestring
using namespace std;
#define max 50
int 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;jstrings.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;in;i++)
{
for(j=0;j(int)p[i].left.length();j++)
{
if((p[i].left[j]=Ap[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];
}
}
for(j=0;j(int)p[i].right.length();j++)
{
if(!(p[i].right[j]=Ap[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;in;i++)
{
for(j=0;j(int)p[i].left.length();j++)
{
if(p[i].left[j]=Ap[i].left[j]=Z) //有否非终结符
flag++;
}
if(flag0)
{
flag=0;
count++;
}
else
break; //左部没有非终结符,结束
}
if(count==n)
return 1; //属于0型文法
else
{
coutendl所输产生式不属于任何文法。endl;
NONE=0;
retu
您可能关注的文档
最近下载
- 中小学生端午节假期安全教育主题班会PPT课件.pptx VIP
- 机器人等级考试三四级资料-第01课:初识Mixly和Fduino UNO.pptx VIP
- FULING富凌H200空压机中文说明书说明书用户手册.pdf
- Praat语音软件操作手册.docx VIP
- 2025-2026学年重庆市江津实验中学、田家炳中学、李市中学、白沙中学等金砖六校九年级(上)期末化学模拟试卷(含答案).pdf VIP
- 阿特拉斯•科普柯 冷冻式干燥机.pdf VIP
- 重庆市九龙坡区2024-2025学年九年级上学期期末考试数学试题(含答案与解析).pdf VIP
- 浙江省杭州市富阳区2023-2024学年三年级上学期数学期末试卷.docx VIP
- TXFQC-合成橡胶消防水带.pdf VIP
- 重庆市九龙坡区渝高教育集团2024-2025学年九年级上学期期末考试物理试题(含答案).pdf VIP
原创力文档

文档评论(0)