flag=false; }
void Action3()//状态3 {
if((ch=='+')||(ch=='*')||(ch==')')||(ch=='#'))//下一个操作符为+,*,),#规约 {
cout< print(point-1,strToken); cout<<\→F归约\ r.pop(); r.get_top(Y); Goto(int(Y),'T'); } else flag=false; } void Action4_6_7(int x)//状态4,6,7 { if(ch=='i')//下一个操作符为i ,移进 { cout< print(point-1,strToken); cout<<\ cout< ch=strToken[point++]; } else if(ch=='(')//下一个操作符为( ,移进 { cout< print(point-1,strToken); cout<<\ cout< ch=strToken[point++]; } else flag=false; } void Action5()//状态5 { if((ch=='+')||(ch=='*')||(ch==')')||(ch=='#'))//下一个操作符为+,*,),#规约 { cout< print(point-1,strToken); cout<<\→i归约\ r.pop(); r.get_top(Y); Goto(int(Y),'F'); } else flag=false; } void Action8()//状态8 { if(ch=='+')//下一个操作符为+ ,移进 { cout< print(point-1,strToken); cout<<\状态6入栈\ r.push(6); l.push(ch); ch=strToken[point++]; } else if(ch==')')//下一个操作符为) ,移进 { cout< print(point-1,strToken); cout<<\状态11入栈\ r.push(11); l.push(ch); ch=strToken[point++]; } else flag=false; } void Action9()//状态9 { if(ch=='*')//下一个操作符为* ,移进 { cout< print(point-1,strToken); cout<<\状态7入栈\ r.push(7); l.push(ch); ch=strToken[point++]; } else if((ch=='+')||(ch==')')||(ch=='#'))//下一个操作符为+,,),#规约 { cout< print(point-1,strToken); cout<<\→E+T归约\ r.pop(); r.pop(); r.pop(); r.get_top(Y); Goto(int(Y),'E'); } else flag=false; } void Action10()//状态10 { if((ch=='+')||(ch=='*')||(ch==')')||(ch=='#'))//下一个操作符为+,*,),#规约 { cout< r.out1(); l.out(); l.pop(); l.pop(); l.pop(); l.push('T'); print(point-1,strToken); cout<<\→T*F归约\ r.pop(); r.pop(); r.pop(); r.get_top(Y); Goto(int(Y),'T'); } else flag=false; } void Action11()//状态11 { if((ch=='+')||(ch=='*')||(ch==')')||(ch=='#'))//下一个操作符为+,*,),#规约 { cout< print(point-1,strToken); cout<<\→(E)归约\ r.pop(); r.pop(); r.pop(); r.get_top(Y); Goto(int(Y),'F'); } else flag=false; } void run()//规约 { cout<<\请输入要规约的字符串:\ cin>>strToken; cout<<\步骤\\t\状态栈\\t\符号栈\\t\输入串\\t\\t\动作说明\
相关推荐: