SDUTOJ 1837 小型Basic编译器问题
来源:互联网 发布:阿里云如何做代理商 编辑:程序博客网 时间:2024/05/20 23:34
小型Basic编译器问题
Time Limit: 1000MS Memory Limit: 65536KB
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语句。
(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
输出程序的运行结果,文件头尾都不需要多余空行。
Example Input
1 LET A=102 LET I=03 LET X=I+I4 LET T=15 LET X=X+T6 PRINT X7 LET T=18 LET I=I+T9 IF A>I10 GOTO 311 STOP
Example Output
X=1X=3X=5X=7X=9X=11X=13X=15X=17X=19
Hint
写个解释程序,拿来练练面向对象。
坑:
1、空格,可能有连续的空格;
2、IF GOTO后面跟的是表达式,也就是说可以是整数,X+I,X>U这类;
然后愉快的AC吧
#include<iostream>#include<cstring>#include<algorithm>#include<cmath>#include<string>#include<climits>#include<stack>#include<queue>#include<map>#include<set>#include<list>#include<cstdio>using namespace std;#define maxn 110int Var[30];class Fun{private: string sentence; int pid; string operation; string in; int getPid(); int cal(string); //计算表达式的值 int _let(void);//LET语句 int _goto(void);//GOTO语句 int _if(void);//if语句 int _print(void); int _stop(void);public: Fun(){} static void run(int _pid);//全文运行 static int getVar(char);//获得变量在数组Var中的位置 static bool isNumber(char); static bool isUpLetter(char); static int getNumber(string); void ini(string);//初始化单行语句 int runLine(void);//单行解释运行}Run[maxn];void Fun::run(int _pid){ if(_pid==-1) return ; int Next=Run[_pid].runLine(); run(Next);}int Fun::getVar(char temp){ return temp-'A';}int Fun::cal(string str){ if(isUpLetter(str[0])) { if(str[1]=='+') return Var[getVar(str[0])]+Var[getVar(str[2])]; else return (int)(Var[getVar(str[0])]>Var[getVar(str[2])]); } return getNumber(str);}int Fun::_let(){ Var[getVar(in[0])]=cal(in.substr(2,in.size()-2));// cout<<in<<endl;// cout<<in.substr(2,in.size()-2)<<endl; return pid+1;}int Fun::_print(){ printf("%s=%d\n",in.c_str(),Var[getVar(in[0])]); return pid+1;}int Fun::_if(){ if(cal(in)!=0) return pid+1; return pid+2;}int Fun::_goto(){ return cal(in);}int Fun::_stop(){ return -1;}int Fun::getNumber(string str){ if(str.size()<=0) return 0; int temp=0; bool flag; if(str[0]=='-') { flag=false; str.erase(0,1); } else flag=true;// cout<<"str=="<<str<<endl; int len=str.size(); for(int i=0;i<len;++i) { temp=temp*10; temp+=str[i]-'0'; }// cout<<"temp=="<<temp<<endl; if(!flag) temp*=-1; return temp;}bool Fun::isNumber(char temp){ if(temp>='0' && temp<='9') return true; return false;}bool Fun::isUpLetter(char temp){ if(temp>='A' && temp<='Z') return true; return false;}int Fun::getPid(){ int len=sentence.size(); int num=0; while(sentence.size()>0 && isNumber(sentence[0])) { num=num*10+sentence[0]-'0'; sentence.erase(0,1); } if(sentence[0]==' ') sentence.erase(0,1); return num;}void Fun::ini(string str){ sentence=str; pid=getPid(); if(sentence=="STOP") operation=sentence; else { operation=sentence.substr(0,sentence.find(' ')); sentence.erase(0,operation.size()+1); in=sentence; }}int Fun::runLine(){ int Next; switch(operation[0]) { case 'L':Next=_let();break; case 'P':Next=_print();break; case 'G':Next=_goto();break; case 'I':Next=_if();break; case 'S':Next=_stop();break; default:Next=-1; } return Next;}int main(){ char temp[maxn*10]; int t=1; while(gets(temp)) { string str=string(temp); int len=str.size(); for(int i=1;i<len;++i) { if(str[i]==' ' && str[i-1]==' ') { str.erase(i,1); i--; len--; } } while(str[0]==' ') str.erase(0,1); Run[t++].ini(str); } memset(Var,0,sizeof(Var)); Fun::run(1);}/***************************************************User name: zxw140102李洪丰Result: AcceptedTake time: 0msTake Memory: 168KBSubmit time: 2016-09-30 18:59:15****************************************************/
0 0
- SDUTOJ 1837 小型Basic编译器问题
- SDUTOJ 2099 - 小型Basic编译器问题(模拟)
- 小型Basic编译器问题
- 小型Basic编译器问题
- 小型Basic编译器问题
- 小型Basic编译器问题
- sdut 2099 小型Basic编译器问题
- 约瑟夫问题 sdutoj 1197
- SDUTOJ. LCS问题.(DP)
- 约瑟夫问题 sdutoj 1197
- C#开发一个小型编译器
- basic编译器代码
- sdutoj 1157 小鼠迷宫问题
- [2074]区间覆盖问题 sdutOJ
- 不敢死队问题 sdutoj 2056
- sdutoj
- SDUTOJ
- SDUToj
- String拼接问题
- this指针
- 恨无常
- 记录两个问题
- ROS环境变量设置roscd、rosed无法找到路径
- SDUTOJ 1837 小型Basic编译器问题
- ovs-dpdk和ovs-kernel的checksum处理
- uva 673
- HUD1017
- inno 卸载
- web 框架
- 九月英语总结
- uva 10050
- mybatis总结——常见配置及方法