- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实 验 报 告
(20 / 2017 学年 第 学期)
课程名称 实验名称
实 验 报 告
实验名称 指导教师 实验类型 实验学时 实验时间 实验目的和要求
二、实验环境(实验设备)
X86计算机
:Windows 7 32bit
IDE: CodeBlokcs 16.02
:: 三、实验原理及内容
原理:
将中缀表达式转换成后缀表达式,再将后缀表达式中每一个赋值,递归枚举的方法赋值情况用map映射将每一个字母与当前枚举的值一一映射,每一种情况后缀表达式计算计算后缀表达式的值,情况如果是真,记录到zhen的不定长数组中,如果是假,记录到名为jia的vector不定长数组中。根据zhen和jia的不定长数组来打印主析取范式和主合取范式。
实现任意数量的字母的主析取范式求取和主合取范式求取,以及真值表打印。
实 验 报 告
:预处理
这样,所有的运算符只一个字符,后期处理起来更加方便。
{
string::iterator i=zhong.begin(); //string类迭代器需在头文件 int flag=1;
while(flag)
{
flag=0;
for(i=zhong.begin();i!=zhong.end();++i)
{
if(*i==)
{
zhong.erase(i);
flag=1;
break;
}
if(*i===)
{
zhong.erase(i);
flag=1;
break;
}
}
}
}
第二步:将中缀表达式转换后缀表达式
利用栈和优先级函数来将中缀表达式转换成后缀表达式,此函数另一个功能是将中缀表达式中所有出现过的字母变量都保存包名为alpha的string类中(string类为STL中的string,需要在头文件加入#includestring),并且alpha中不出现重复字母,这样,通过alpha.size()函数就可以得到所有字母变量的个数,并且方便后面枚举赋值映射。
全局变量:
string zhong; //中缀表达式
char hou[1000]; //后缀表达式
string alpha; //存放所有字母变量
优先级函数:
int icp(char a) //栈外优先级
{
if(a==#) return 0;
if(a==() return 12;
if(a==!) return 10;
if(a==) return 8;
if(a==|) return 6;
if(a==-) return 4;
if(a==) return 2;
if(a==)) return 1;
}
int isp(char a) //栈内优先级
{
if(a==#) return 0;
if(a==() return 1;
if(a==!) retur
您可能关注的文档
最近下载
- 2011届高考化学一轮复习专题模拟检测:专题5_氮族元素及其化合物.doc VIP
- Unit6大单元教学整体单元分析课件人教版九年级英语全册.ppt
- 教育信息化背景下跨学科教学资源的数字化建设.docx
- 城镇直埋供热管道电预热安装施工工法(技术方案).pdf VIP
- 2014造口治疗师培训个案发展计划及产品册造口学校.pdf VIP
- 标准化乡镇卫生院制度.doc
- 2026年湖南科技职业学院单招职业技能考试必刷测试卷完美版.docx VIP
- 2024年9月8日贵州省黔西南州州直遴选(事业单位考聘)笔试真题及答案解析.doc VIP
- 2025年兵棋章节答案.docx VIP
- 酒店工程部计件量化方案(3篇).docx VIP
文档评论(0)