程序功能:布尔表达式翻译成四元式

该博客详细介绍了如何使用LR分析法将布尔表达式转换为四元式,包括解析布尔表达式的文法,定义状态栈和符号栈,以及通过输入字符进行移进和规约操作,最终生成中间代码四元式。
摘要由CSDN通过智能技术生成
#include<iostream>
#include<string>
#include<vector>
#include<iomanip> 
using namespace std;
                              //and	or	not	true false(	  )	  i	 rop   # 
           int action[18][10]={ { 0	, 0	 ,4	,5	, 6	 ,7	, 0	, 8	, 0	,  0},//0
								{ 9	, 0	 ,0	,0	, 0	 ,0	,-2	, 0	, 0	,100},//1
								{-2	,10	 ,0	,0	, 0	 ,0	,-2	, 0	, 0	, -2},//2
								{-4	,-4	 ,0	,0	, 0	 ,0	,-4	, 0	, 0	, -4},//3
								{ 0	, 0	 ,4	,5	, 6	 ,7	, 0	, 8	, 0	,  0},//4
								{-7	,-7	 ,0	,0	, 0	 ,0	,-7	, 0	, 0	, -7},//5
								{-8	,-8	 ,0	,0	, 0	 ,0	,-8	, 0	, 0	, -8},//6
								{ 0	, 0	 ,4	,5	, 6	 ,7	, 0	, 8	, 0	,  0},//7
								{ 0	, 0	 ,0	,0	, 0	 ,0	, 0	, 0	,13	,  0},//8
								{ 0	, 0	 ,4	,5	, 6	 ,7	, 0	, 8	, 0	,  0},//9
								{ 0	, 0	 ,4	,5	, 6	 ,7	, 0	, 8	, 0	,  0},//10
								{-5	,-5	 ,0	,0	, 0	 ,0	,-5	, 0	, 0	, -5},//11
								{ 9	, 0	 ,0	,0	, 0	 ,0	,16	, 0	, 0	,  0},//12
								{ 0	, 0	 ,0	,0	, 0	 ,0	, 0	,17	, 0	,  0},//13
								{-1	,10  ,0	,0	, 0	 ,0	,-1	, 0	, 0	, -1},//14
								{-3	,-3	 ,0	,0	, 0	 ,0	,-3	, 0	, 0	, -3},//15
								{-6	,-6	 ,0	,0	, 0	 ,0	,-6	, 0	, 0	, -6},//16
								{-9	,-9	 ,0	,0	, 0	 ,0	,-9	, 0	, 0	, -9}};//17

                               //B   T    F
           int gotol[18][3]={   {1	,2	, 3},//0
							    {0	,0	, 0},//1
								{0	,0	, 0},//2
								{0	,0	, 0},//3
								{0	,0	,11},//4
								{0	,0	, 0},//5
								{0	,0	, 0},//6
								{12	,2	, 3},//7
								{0	,0	, 0},//8
								{0	,14	, 3},//9
                                {0	,0	,15},//10
								{0	,0	, 0},//11
								{0	,0	, 0},//12
                                {0	,0	, 0},//13
								{0	,0	, 0},//14
								{0	,0	, 0},//15
								{0	,0	, 0},//16
                                {0	,0	, 0}};//17

//终结符集合
string endls[10]={"and","or","not","true","false", "(",")", "i","rop","#" };
//非终结符集合
string noends[3]={"B","T","F"};
//产生式集合
string products[10]={"B","B and T", "T","T or F","F","not F","( B )","true", "false","i rop i"};
//栈类
class statestack
{
	private:
		int *base;//栈底指针
		int *top;//栈顶
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值