九度OJ 1089:数字反转 (数字反转)

时间限制:1 秒

内存限制:32 兆

特殊判题:否

提交:3059

解决:1678

题目描述:

    12翻一下是21,34翻一下是43,12+34是46,46翻一下是64,现在又任意两个正整数,问他们两个数反转的和是否等于两个数的和的反转。

输入:

    第一行一个正整数表示测试数据的个数n。
    只有n行,每行两个正整数a和b(0<a,b<=10000)。

输出:

    如果满足题目的要求输出a+b的值,否则输出NO。

样例输入:
2
12 34
99 1
样例输出:
46
NO
来源:
2005年上海交通大学计算机研究生机试真题

思路:

数字反转可借助字符串来实现。(见代码1)

更好的办法是直接反转。(见代码2)


代码1:

#include <stdio.h>
#include <string.h>
     
#define MAX 7
 
void fanzhuan(char *a, char *af)
{
    int i;
    int len = strlen(a);
    for (i=0; i<len; i++)
        af[i] = a[len-1-i];
    for (i=len-1; i>=0; i--)
    {
        if (af[i] > '0')
        {
            af[i+1] = '\0';
            break;
        }
    }   
}       
         
void add(char *a, char *b, char *sum)
{       
    int lena=strlen(a), lenb=strlen(b); 
    int i;  
    char tmp;
     
    for (i=0; i<lena/2; i++)
    {
        tmp = a[i];
        a[i] = a[lena-1-i];
        a[lena-1-i] = tmp;
    }
    for (i=0; i<lenb/2; i++)
    {   
        tmp = b[i];
        b[i] = b[lenb-1-i];
        b[lenb-1-i] = tmp;
    }
     
    for (i=lena; i<MAX; i++)
        a[i] = '0';
    for (i=lenb; i<MAX; i++)
        b[i] = '0';
    for (i=0; i<MAX; i++)
        sum[i] = '0';
/*
    for (i=0; i<MAX; i++)
        printf("%c", a[i]);
    printf("\n");
    for (i=0; i<MAX; i++)
        printf("%c", b[i]);
    printf("\n");
    //printf("a[0] = %c\n", a[0]);
    //printf("b[0] = %c\n", b[0]);
    //printf("sum[0] = %c\n", sum[0]);
*/
    for (i=0; i<MAX-1; i++)
    {
        sum[i] += a[i] - 48 + b[i] - 48;
        //printf("a[i] = %c\n", a[i]);
        //printf("b[i] = %c\n", b[i]);
        //printf("sum[i] = %c\n", sum[i]);
        if (sum[i] > '9')
        {
            sum[i+1] = ((sum[i]-48)/10) + 48;
            sum[i] = ((sum[i]-48)%10) + 48;
        }
    }
    //for (i=0; i<MAX; i++)
    //  printf("%c", sum[i]);
    //printf("\n");
 
    for (i=MAX-1; i>=0; i--)
    {
        if (sum[i] > '0')
        {
            sum[i+1] = '\0';
            break;
        }
    }
    if (i < 0)
        sum[1] = '\0';
 
    int lens = strlen(sum);
    for (i=0; i<lens/2; i++)
    {   
        tmp = sum[i];
        sum[i] = sum[lens-1-i];
        sum[lens-1-i] = tmp;
    }
}
 
int main(void)
{
    char a[10000][MAX], b[10000][MAX];
    char af[MAX], bf[MAX], sum[MAX], sumf[MAX], fsum[MAX];
    int n;
    int i;
     
    while (scanf("%d", &n) != EOF) 
    {   
        for (i=0; i<n; i++)
            scanf("%s%s", a[i], b[i]);
         
        for (i=0; i<n; i++)
        {   
            fanzhuan(a[i], af);
            //printf("af = %s\n", af);
            fanzhuan(b[i], bf);
            //printf("bf = %s\n", bf);
            add(a[i], b[i], sum);
            //printf("sum = %s\n", sum);
            fanzhuan(sum, sumf);
            //printf("sumf = %s\n", sumf);
            add(af, bf, fsum);
            //printf("fsum = %s\n", fsum);
            if (strcmp(fsum, sumf) == 0)
                printf("%s\n", sum);
            else
                printf("NO\n");
        }
    }
         
    return 0;
 }                                                                                              
/**************************************************************
    Problem: 1089
    User: liangrx06
    Language: C
    Result: Accepted
    Time:0 ms
    Memory:976 kb
****************************************************************/



代码2:

#include <stdio.h>
#include <string.h>
 
int fz(int a)
{
    int n = 0;
    while (a)
    {
        n = n*10 + a%10;
        a /= 10;
    }
    return n;
}
 
int main(void)
{
    int n, i;
    int a, b;
 
    scanf("%d", &n);
    for (i=0; i<n; i++)
    {
        scanf("%d%d", &a, &b);
        if (fz(a)+fz(b) == fz(a+b))
            printf("%d\n", a+b);
        else
            printf("NO\n");
    }
 
    return 0;
}
/**************************************************************
    Problem: 1089
    User: liangrx06
    Language: C++
    Result: Accepted
    Time:0 ms
    Memory:1020 kb
****************************************************************/


转载于:https://www.cnblogs.com/liangrx06/p/5083943.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,根据提供的引用内容,我无法回答关于西北工业大学计算机考研真题在百度云上的问题。引用提供了一个关于字符串合并的样例输入和输出,而引用和引用提供了一些与西北工业大学计算机研究生的相关信息。但是,这些引用内容都没有提供与百度云相关的信息。如果您有关于其他方面的问题,我将很乐意为您提供帮助和回答。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [九度OJ 题目1471:合并符串](https://blog.csdn.net/SJF0115/article/details/8609716)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [2021西北工业大学考研历年真题](https://blog.csdn.net/weixin_42502288/article/details/118177726)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [undefined](undefined)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值