zoj acm 1205

  1. #include <iostream>
  2. #include <list>
  3. #include <string>
  4. #include <algorithm>
  5. using namespace std;
  6. inline int fromchartoint(char);
  7. inline char frominttochar(int);
  8. int main(){
  9.     string na, nb;
  10.     int carry;
  11.     int len;
  12.     int sum;
  13.     list<char> result;
  14.     list<char>::iterator pos;
  15.     while(cin >> na >> nb){
  16.         carry=0;
  17.         result.clear();
  18.         reverse(na.begin(),na.end());
  19.         reverse(nb.begin(),nb.end());
  20.         len = max(na.length(), nb.length());
  21.         for(int i=0; i<len; i++){
  22.             sum = carry;
  23.             if(i<na.length())
  24.                 sum += fromchartoint(na[i]);
  25.             if(i<nb.length())
  26.                 sum += fromchartoint(nb[i]);
  27.             if(sum>=20){
  28.                 carry=1;
  29.                 sum-=20;
  30.             }
  31.             else{
  32.                 carry=0;
  33.             }
  34.             result.push_front(frominttochar(sum));
  35.         }
  36.         if(carry==1)
  37.             result.push_front(frominttochar(carry));
  38.         for(pos=result.begin();pos!=result.end();pos++){
  39.             cout << *pos;
  40.         }
  41.         cout << endl;
  42.     }
  43. }
  44. inline int fromchartoint(char c){
  45.     if(c>='0'&&c<='9')
  46.         return c-'0';
  47.     else
  48.         return c-'a'+10;
  49. }
  50. inline char frominttochar(int i){
  51.     if(i>=0&&i<=9)
  52.         return i+'0';
  53.     else
  54.         return i-10+'a';
  55. }
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值