小型Basic编译器问题

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
在这里插入图片描述

#include<bits/stdc++.h>
using namespace std;
int num[130];
string str[105];
int p,f;
int n;

int str_to_int(string s){
    int t=1,n=s.size()-1;
    int num=0;
    while(n>=0){
        num+=(s[n]-'0')*t;
        t*=10;
        n--;
    }
    return num;
}

void LET(){
    while(str[f][p]==' ') p++;
    int A=str[f][p];
    string temp="",temp1="";
    p++;
    if(str[f][p]=='=') p++;
    if(isdigit(str[f][p])){
        while(isdigit(str[f][p])){ temp+=str[f][p]; p++; }
        int B=str_to_int(temp);
        num[A]=B;
    }else if(str[f][p+1]=='+')
        num[A]=num[str[f][p]]+num[str[f][p+2]];
}

void PRINT(){
    while(str[f][p]==' ') p++;
    char c=str[f][p];
    cout<<c<<"="<<num[c]<<endl;
}

int IF(){
    while(str[f][p]==' ') p++;
    if(str[f][p+1]=='>')
        if(num[str[f][p]]>num[str[f][p+2]]) return 1;
    return 0;
}

int main(){
    n=1;
    while(getline(cin,str[n++])){}
    while(f<n){
        p=0;
        while(isdigit(str[f][p]) || str[f][p]==' ') p++;
        string temp="";
        while(isalpha(str[f][p])){ temp+=str[f][p]; p++; }
        if(temp=="LET") LET();
        else if(temp=="PRINT") PRINT();
        else if(temp=="IF"){
            if(IF()==1) f+=1;
            else f+=2;
            continue;
        }
        else if(temp=="GOTO"){
            while(str[f][p]==' ') p++;
            temp="";
            while(isdigit(str[f][p])){ temp+=str[f][p]; p++; }
            f=str_to_int(temp);
            continue;
        }else if(temp=="STOP") return 0;
        f++;
    }
    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值