1037: 最簡單的電腦

來源:互聯網
上載者:User

標籤:

1037: 最簡單的電腦時間限制: 1 Sec  記憶體限制: 128 MB
提交: 187  解決: 134
[提交][狀態][討論版]題目描述一個名叫是 PigHeadThree 的研究組織設計了一台實驗用的電腦,命名為 PpMm。PpMm只能執行簡單的六種命令 A,B,C,D,E,F;只有二個記憶體 M1,M2;三個寄存器 R1,R2,R3。六種命令的含義如下:
命令 A:將記憶體 M1 的資料裝到寄存器 R1 中;
命令 B:將記憶體 M2 的資料裝到寄存器 R2 中;
命令 C:將寄存器 R3 的資料裝到記憶體 M1 中;
命令 D:將寄存器 R3 的資料裝到記憶體 M2 中;
命令 E:將寄存器 R1 中的資料和寄存器 R2 中的資料相加,結果放到寄存器 R3 中;
命令 F:將寄存器 R1 中的資料和寄存器 R2 中的資料相減,結果放到寄存器 R3 中。
你的任務是:設計一個程式類比 PpMm 的運行。輸入有若干組,每組有 2 行,第一行是 2 個整數,分別表示 M1 和 M2 中的初始內容;第二行是一串長度不超過 200 的由大寫字母 A 到 F 組成的命令串,命令串的含義如上所述。輸出對應每一組的輸入,輸出只有一行,二個整數,分別表示 M1,M2 的內容;其中 M1 和 M2 之間用逗號隔開。範例輸入
100 288ABECED876356 321456ABECAEDBECAF
範例輸出
388,3882717080,1519268
提示 來源

#include <iostream>
using namespace std;
int main(){
 int i,m1,m2,r1,r2,r3;
 string str;
 while(cin>>m1>>m2){
  r1=0;
  r2=0;
  r3=0;
  cin>>str;
  for(i=0;str[i]!=‘\0‘;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;
  }
  cout<<m1<<","<<m2<<endl;
 }
 return 0;
}

1037: 最簡單的電腦

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.