Problem Description
编写一个TinyBasic语言的解释程序,对于任何一个给出的正确的TinyBasic语言的程序,你的程序能运行它并得到正确的结果。那么,怎样的TinyBasic的程序叫做正确的呢? (1)符合TinyBasic语言的语法规则; (2)程序执行时会产生一个或多个输出,可以中断(即程序不会进入无限循环状态)。 TinyBasic语言的语法规则: (1)每一行的TinyBasic程序都是下面这样的形式(所有出现的字母均为大写) [<空格>]<行号><空格><语句> 其中,[<空格>]中可以有任意个空格,当然也可以没有; <行号>中一定要有行号,从1开始,依次递增1; <空格>中至少有一个空格; <语句>应为下面的语句之一: LET<空格><变量>=<表达式> PRINT<空格><变量> GOTO<空格><表达式> IF<空格><表达式> STOP (2)定义变量和表达式的规则为 <变量>必须是单个的大写英文字母,存储一个整数值; <表达式>为 <常量> 范围在[-10000…10000]内的整数常量,比如0,-5,34 <变量>+<变量> 两个变量所代表的是有符号整数 <变量>><变量> 大于号,真为1,假为0 (3)表达式中和LET语句的=(等号)两边没有空格; (4)TinyBasic的程序最多只有100行。 执行TinyBasic语言程序的规则: (1)从程序中的第1行开始执行; (2)程序中用到的所有变量的初始值均为0; (3)语句连续执行除非碰到IF或GOTO语句; (4)5种语句的定义 LET 给变量赋值。若两个变量相加,相加的结果在[-10000…10000]之内。 PRINT <变量名>=<值>的格式打印变量的值。左对齐,并单独占用一行;行中无任何多余空格。 GOTO 跳到行号为<表达式>的值的一行。<表达式>不需要是一个常量;<表达式>的值是程序中的有效行号。 IF 如果表达式的值非0继续执行下一行;如果表达式的值为0跳过下一行,执行下一行的下一行。在IF语句以下至少还应该有两条语句。 STOP 终止执行。TinyBasic程序一定会执行到STOP语句(如果你的解释程序是正确的话);TinyBasic程序可能包含一个以上的STOP语句;程序的最后一句不一定是STOP语句。
Input
输入数据只有一组,包含一个程序,没有多余的空行,每一行为一条语句,具体要求按上面的解释。你编写的程序要正确地运行该TinyBasic程序。
Output
输出程序的运行结果,文件头尾都不需要多余空行。
Sample Input
1 LET A=10 2 LET I=0 3 LET X=I+I 4 LET T=1 5 LET X=X+T 6 PRINT X 7 LET T=1 8 LET I=I+T 9 IF A>I 10 GOTO 3 11 STOPSample Output
X=1 X=3 X=5 X=7 X=9 X=11 X=13 X=15 X=17 X=19 #include<stdio.h> #include<string.h> struct node { char key[50]; char var[50]; }str[110]; int a[30]; int main() { memset(a, 0, sizeof(a)); int l=0,n; while(scanf("%d",&n)!=EOF) { char s[50],s1[50]; scanf("%s",s); strcpy(str[n].key,s); l++; if(strcmp(s,"STOP")!=0) { scanf("%s",s1); strcpy(str[n].var,s1); } } int j; for(j=1;j<=l;) { if(strcmp(str[j].key,"LET")==0) { int i; int m=(int)(str[j].var[0]-'A'); if((str[j].var[2]>='0'&&str[j].var[2]<='9')||str[j].var[2]=='-') { int k=strlen(str[j].var); int l1=0,p=1; for(i=k-1;str[j].var[i]!='='&&str[j].var[i]!='-';i--) { l1+=(str[j].var[i]-'0')*p; p*=10; } if(str[j].var[2]=='-') a[m]=-l1; else a[m]=l1; //printf("shu %c=%d\n",str[j].var[0],a[m]); } else if(str[j].var[3]=='+') { int m1=(int)(str[j].var[2]-'A'); int m2=(int)(str[j].var[4]-'A'); a[m]=a[m1]+a[m2]; } else if(str[j].var[3]=='>') { int m1=(int)(str[j].var[2]-'A'); int m2=(int)(str[j].var[4]-'A'); if(a[m1]>a[2]) a[m]=1; else a[m]=0; //printf("> %c=%d\n",str[j].var[0],a[m]); } j++; } else if(strcmp(str[j].key,"PRINT")==0) { int m=(int)(str[j].var[0]-'A'); printf("%c=%d\n",str[j].var[0],a[m]); j++; } else if(strcmp(str[j].key,"IF")==0) { int m1=(int)(str[j].var[0]-'A'); int m2=(int)(str[j].var[2]-'A'); if(a[m1]<=a[m2]) j++; j++; } else if(strcmp(str[j].key,"GOTO")==0) {int i,l1=0,k,p=1; k=strlen(str[j].var); for(i=k-1;i>=0;i--) { l1+=(int)(str[j].var[i]-'0')*p; p*=10; } j=l1; } else if(strcmp(str[j].key,"STOP")==0) { break; } } return 0; }