最簡(jiǎn)單的計(jì)算機(jī)

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 1781    Accepted Submission(s): 1054


Problem Description
一個(gè)名叫是PigHeadThree的研究組織設(shè)計(jì)了一臺(tái)實(shí)驗(yàn)用的計(jì)算機(jī),命名為PpMm。PpMm只能執(zhí)行簡(jiǎn)單的六種命令A(yù),B,C,D,E,F(xiàn);只有二個(gè)內(nèi)存M1,M2;三個(gè)寄存器R1,R2,R3。六種命令的含義如下:
  命令A(yù):將內(nèi)存M1的數(shù)據(jù)裝到寄存器R1中;
  命令B:將內(nèi)存M2的數(shù)據(jù)裝到寄存器R2中;
  命令C:將寄存器R3的數(shù)據(jù)裝到內(nèi)存M1中;
  命令D:將寄存器R3的數(shù)據(jù)裝到內(nèi)存M2中;
  命令E:將寄存器R1中的數(shù)據(jù)和寄存器R2中的數(shù)據(jù)相加,結(jié)果放到寄存器R3中;
  命令F:將寄存器R1中的數(shù)據(jù)和寄存器R2中的數(shù)據(jù)相減,結(jié)果放到寄存器R3中。
你的任務(wù)是:設(shè)計(jì)一個(gè)程序模擬PpMm的運(yùn)行。
 

Input
有若干組,每組有2行,第一行是2個(gè)整數(shù),分別表示M1和M2中的初始內(nèi)容;第二行是一串長(zhǎng)度不超過(guò)200的由大寫字母A到F組成的命令串,命令串的含義如上所述。
 

Output
對(duì)應(yīng)每一組的輸入,輸出只有一行,二個(gè)整數(shù),分別表示M1,M2的內(nèi)容;其中M1和M2之間用逗號(hào)隔開(kāi)。

其他說(shuō)明:R1,R2,R3的初始值為0,所有中間結(jié)果都在-2^31和2^31之間。
 

Sample Input
100 288 ABECED 876356 321456 ABECAEDBECAF
 

Sample Output
388,388 2717080,1519268
 

Author
SmallBeer(CML)
 

Source
 

Recommend
lcy
 
 
#include<stdio.h>
#include
<string.h>
char str[210];
int main()
{
int M1,M2,R1,R2,R3;
int i,len;
while(scanf("%d%d",&M1,&M2)!=EOF)
{
R1
=R2=R3=0;
scanf(
"%s",&str);
len
=strlen(str);
for(i=0;i<len;i++)
{
if(str[i]=='A')R1=M1;
else if(str[i]=='B') R2=M2;
else if(str[i]=='C') M1=R3;
else if(str[i]=='D') M2=R3;
else if(str[i]=='E') R3=R1+R2;
else if(str[i]=='F') R3=R1-R2;
}
printf(
"%d,%d\n",M1,M2);
}
return 0;
}