最簡單的計算機

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


Problem Description
一個名叫是PigHeadThree的研究組織設(shè)計了一臺實驗用的計算機,命名為PpMm。PpMm只能執(zhí)行簡單的六種命令A(yù),B,C,D,E,F(xiàn);只有二個內(nèi)存M1,M2;三個寄存器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è)計一個程序模擬PpMm的運行。
 

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

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

其他說明: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;
}