版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上#include <iostream>#include <set>#include <map>#include <string>#include <algorithm>using namespace std;multimap<char, string> production;set<char> unFinal;set<char>final;char S;void Input()char ch;string str;cout<<"非终结符(以 0 结尾)
2、: "while(cin>>ch && ch!='0') unFinal.insert(ch);cout<<"终结符 (以 F 结尾): "while(cin>>ch && ch!='F')final.insert(ch); cout<<"开始符: "cin>>S;cout<<"产生式 (以 0 0 结尾):"<<endl;while(cin>>ch>>s
3、tr && ch!='0')production.insert(make_pair(ch, str);string solve(char ch)string str("(");string re("");string ch_18;string str18,str28;int len,i,j,flag=10,strlen,sslen,lslen,num=0;multimap<char, string>:iterator iter = production.find(ch);int n = production.c
4、ount(ch);for(i=0; i<n; i+, +iter) len=iter->second.size();str1i.append(iter->second);str2i=str1i;str2i.replace(1,1,"|");ch_1i=iter->second.substr(len-1);for(i=0; i<n; i+) if(ch_1i>="A"&&ch_1i<="Z") for( j=i+1;j<n;j+)if(ch_1i=ch_1j) flag=i
5、;str.push_back('(');str.append(str2i.substr(0); str.append(str2j.substr(0);for( ;j<n;j+)str1j.assign(str1j+1);ch_1j.assign(ch_1j+1); if(i=flag)strlen=str.size(); str.replace(strlen-1,1,")"); str.append(ch_1i); str.push_back('|');else str.append(str1i.substr(0);if(n>=2
6、)/相同左部产生式个数大于等于2个时,才输出"|" str.push_back('|'); sslen=str.size();for(i=0; i<n; i+) if(ch_1i<"A"|ch_1i>"Z")num+;if(num>=2)str.push_back('(');for(i=0; i<n; i+) if(ch_1i<"A"|ch_1i>"Z")str.append(ch_1i);if(i!=n-1) str.p
7、ush_back('|');if(num>=2)str.push_back(')');lslen=str.size(); for(int i=0; i<str.size(); i+)if(unFinal.find(stri)!=unFinal.end() /stri是非终结符if(stri != ch) /是其他非终结符re = solve(stri);str.replace(i, 1, re);i += re.size()-1;/下标后移 Notice!else /此非终结符就是chstr.replace(i, 1, "*");str.replace(sslen-1,lslen-sslen+1,str.substr(sslen); str.push_back(')');return str;int main()Input();cout<<endl<<"输出正规式
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 IEC TS 63126:2025 RLV EN Guidelines for qualifying PV modules,components and materials for operation at high temperatures
- 右脚踝扭伤宣教
- 门诊部科普小知识
- 住院病人探视宣教
- 骨质疏松宣教手册
- 八旗制度管理员工培训
- 苏课新版八年级生物上册月考考试试题及答案
- 劳务外包协议书范本
- 债务转让协议书怎么写
- 暑假消防教育课件
- 2025陕西延安市安塞区总工会招聘工会社会工作者8人考试参考试题及答案解析
- 湖南省部分校2025-2026学年高二上学期10月联考语文试题(含答案)(解析版)
- 2025贵州惠水县选聘城市社区工作者3人考试模拟试题及答案解析
- 大学高等数学上习题附答案
- 生产车间现场管理规定
- DB54∕T 0298-2023 电梯使用安全标志与标识
- 机场停机坪地坪施工方案
- 5.15中国工农红军长征与遵义会议教学设计-统编版八年级历史上册
- 2025年成人高考高升专试题(含答案)
- 委托物流运输代理服务合同
- 国际工程总承包合同范本比较:条款、应用与优化策略
评论
0/150
提交评论