小型Basic編譯器問題

2021-07-24 19:52:27 字數 2416 閱讀 6793

time limit: 1000ms

memory limit: 65536kb

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

輸出程式的執行結果,檔案頭尾都不需要多餘空行。

example 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

example output

x=1

x=3x=5

x=7x=9

x=11

x=13

x=15

x=17

x=19

hint

author

#include#includestruct node

str[110];

int a[30];

int main()

//if(strcmp(s,"stop")==0)

//} int j;

for(j=1;j<=l;)

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]=='+')

else if(str[j].var[3]=='>')

j++;

}else if(strcmp(str[j].key,"print")==0)

else if(strcmp(str[j].key,"if")==0)

else if(strcmp(str[j].key,"goto")==0)

j=l1;

}else if(strcmp(str[j].key,"stop")==0)

}return 0;

}

小型Basic編譯器問題

小型basic編譯器問題 time limit 1000ms memory limit 65536kb problem description 編寫乙個tinybasic語言的解釋程式,對於任何乙個給出的正確的tinybasic語言的程式,你的程式能執行它並得到正確的結果。那麼,怎樣的tinybas...

sdut 2099 小型Basic編譯器問題

time limit 1000ms memory limit 65536kb submit statistic problem description 編寫乙個tinybasic語言的解釋程式,對於任何乙個給出的正確的tinybasic語言的程式,你的程式能執行它並得到正確的結果。那麼,怎樣的tin...

編譯器優化問題

今天遇一程式,unsigned char a,b,c a 0x89 b a 1 c a b 在單步除錯的時候,觀察數值發現b的值為0,分析b的值應當為0x44,百思不得其解,通過檢視其彙編語句,發現問題所在。彙編語句如下 mov r7,tmod 0x89 mov a,r7 clr c rrc a a...