码迷,mamicode.com
首页 > 其他好文 > 详细

hdoj 2100 Lovekey 【另类A+B】

时间:2014-09-16 22:06:41      阅读:223      评论:0      收藏:0      [点我收藏+]

标签:大数

直接将a与b相加就好了。

代码:

#include <stdio.h>
#include <string.h>
#define M 210
char a[M], b[M],c[M];
int main(){
    while(scanf("%s%s", a, b) == 2){
        int la = strlen(a)-1;
        int lb = strlen(b)-1;
        memset(c, 0, sizeof(c));
        int k = 0;
        while(la>=0&&lb>=0){
            c[k] = a[la]+(b[lb]-'A');
            la--; lb --; k++;
        }
        while(la>=0){
            c[k++] = a[la]; la--;
        }
        while(lb >= 0){
            c[k++] = b[lb]; lb --;
        }
        //printf("..");
        int i = 0;
        while(i < k){
            if(c[i]>'Z'){
                c[i] -= 26;
                c[i+1] += 1;
            }
            i++;
        }
        if(c[k]){
            c[k++] += 'A';
        }
        while(c[k-1] == 'A'&&k > 0) k --;
        for(i = k-1; i > 0; i --)
            printf("%c", c[i]);
        printf("%c\n", c[0]);
    }
}
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2100

hdoj 2100 Lovekey 【另类A+B】

标签:大数

原文地址:http://blog.csdn.net/shengweisong/article/details/39324199

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!