zoukankan      html  css  js  c++  java
  • 小型Basic编译器问题

    小型Basic编译器问题
    Time Limit: 1000 ms Memory Limit: 65536 KiB
    Submit Statistic
    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 STOP
    Sample 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);
        }
        //if(strcmp(s,"STOP")==0)
        //{
        //    break;
        //}
    
      }
    
      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
    ",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
    ",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
    ",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;
      }
    
    
    

    “`

  • 相关阅读:
    02-CSS基础与进阶-day8_2018-09-10-20-14-46
    02-CSS基础与进阶-day7_2018-09-07-21-42-30
    02-CSS基础与进阶-day7_2018-09-07-20-25-28
    02-CSS基础与进阶-day7_2018-09-07-20-15-37
    02-CSS基础与进阶-day6_2018-09-05-22-35-51
    linux(5)查看历史命令执行记录history
    linux(4)Linux 文件内容查看
    linux(3) 处理目录的常用命令
    linux(2)系统目录结构
    docker(12)使用Dockerfile创建jenkins+python3+pytest环境
  • 原文地址:https://www.cnblogs.com/CCCrunner/p/11781736.html
Copyright © 2011-2022 走看看