A+B UVALive 4660

 //这个题没有我写的那么麻烦,我这样写主要是想练习下快速幂和atoi, itoa函数(字符串转十进制整数,十进制整数转n进制字符串)。


#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <string>
#include <cctype>

using namespace std;
/*快速幂*/
int power(int a, int b) {
    int ans = 1, base = a, i = b;
    while (b) {
        if (b & 1)
            ans *= base;

            base *= base;
            b >>= 1;
    }
//    printf("%d ^ %d power is %d\n", a, i, ans);

    return ans;
}


int main()
{
    int n;
    char a[15], b[15];

    cin >> n;

    while(n--){
        char c;
        int MAXa = 0, MAXb=0;
        cin >> a >> b;
        getchar();

  //      cout << a << " " << b << endl;

        for(int i = 0; a[i]; i++){
            MAXa = (MAXa < a[i]-'0') ? (a[i]-'0') : MAXa;
        }
        for(int i = 0; b[i]; i++){
    //        cout << MAXb << "      ";
            MAXb = (MAXb < b[i]-'0') ? (b[i]-'0') : MAXb;
        }
      //  cout << endl;

        int p, q;
        p = atoi(a);
        q = atoi(b);


//        cout<< "p      q ::" << p << " " << q << endl;
        MAXa += 1;
        MAXb += 1;
//刚开始想的是用itoa函数直接将数变为字符串,然后再将字符串用atoi变为数,然而,,这个MAXa进制是由10进制要变成得进制,而不是由MAXa变为10进制。
//        itoa(p, a, MAXa);
//        itoa(q, b, MAXb);
int a1=0, b1=0, ant=0, bnt=0;
//转换为10进制
        while(p){
            int tmp = p%10;
            a1 += tmp*power(MAXa, ant++);

            p /= 10;
        }
        while(q){
            int tmp = q%10;
            b1 += tmp*power(MAXb, bnt++);
            q /= 10;
        }
/*   //     cout<< "a      b ::" << a1 << " " << b1 << endl;

 //       printf("a:%d   b:%d    %s    %s\n",MAXa, MAXb, a, b);

        p = atoi(a);
        q = atoi(b);
        cout<< "p      q ::" << p << " " << q << endl;

*/
        cout << a1+b1 << endl;

    }
    return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值