九度 題目1340:小A的計算器

 

  1. #include<stdio.h>  
  2. #include<string.h>  
  3. #define E 97  
  4. int main(void)  
  5. {  
  6.     int n,sum,i,j,k,count,carry=0,f=1;  
  7.     char a[10],b[10],re[11],ca,cb;  
  8.     while(scanf("%d",&n)!=EOF)  
  9.     {  
  10.         for(i=0;i<n;i++)  
  11.         {  
  12.             scanf("%s %s",a,b);  
  13.             j=strlen(a)-1;  
  14.             k=strlen(b)-1;  
  15.             count = j>k ? j:k;  
  16.             count+=1;  
  17.             while(j>=0||k>=0)  
  18.             {  
  19.                 if(j<0)  
  20.                     ca='a';  
  21.                 else 
  22.                     ca=a[j];  
  23.                 if(k<0)  
  24.                     cb='a';  
  25.                 else 
  26.                     cb=b[k];  
  27.                 sum=ca+cb-2*E+carry;  
  28.                 re[count--]=sum%26+E;  
  29.                 carry = sum/26;  
  30.                 j--;  
  31.                 k--;  
  32.             }  
  33.  
  34.             count = (strlen(a)>strlen(b) ? strlen(a):strlen(b))+1;  
  35.             if(carry!=0)  
  36.             {  
  37.                 re[0]=carry+E;  
  38.                 j=0;  
  39.             }  
  40.             else 
  41.             {  
  42.                 j=1;  
  43.             }  
  44.             for(;j<count;j++)  
  45.             {  
  46.                 if(!(re[j]=='a' && f))  
  47.                 {   printf("%c",re[j]);  
  48.                     f=0;  
  49.                 }  
  50.             }  
  51.             if(f)  
  52.                 printf("a\n");  
  53.             else 
  54.                 printf("\n");  
  55.             carry=0;  
  56.             f=1;  
  57.         }  
  58.     }  
題目描述:

 以往的操作系統內部的數據表示都是二進制方式,小A新寫了一個操作系統,系統內部的數據表示爲26進制,其中0-25分別由a-z表示。
 現在小A要在這個操作系統上實現一個計算器,這個計算器要能實現26進制數的加法運算。你能幫小A實現這個計算器嗎?

輸入:

 輸入的第一行包括一個整數N(1<=N<=100)。
 接下來的N行每行包括兩個26進制數x和y,它們之間用空格隔開,每個數的位數最多爲10位,我們可以保證相加的結果的位數最多也是10位。每個數會用小A所設計的操作系統中的表示方法來表示,如:bsadfasdf。即每個數的各個位均由26個小寫字母a-z中的一個來表示。
 

輸出:

 輸出x和y相加後的結果,結果也要用題目中描述的26進制數來表示。

樣例輸入:
4
ba cd
c b
b c
ba c
樣例輸出:
dd
d
d
bc
提示:

 1.注意,26進制數的表示方式和10進制數一樣,最右邊是最低位。
 2.輸入的兩個數有可能有前綴0,即a,請在程序中進行處理。
 3.結果中如果出現前綴0,請自動濾除,除非結果就是0。如:結果爲ab時,要輸出b,因爲a表示0。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章