24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1982  |  回复: 1

yihang_Ren

新虫 (初入文坛)

[交流] 杭电oj1002题求助,代码可以运行,和测试数据结果相同已有1人参与

杭电1002题,为什么老是wrong answer,我在DEV-cpp上试过,代码可以运行,结果和测试数据结果也是相同的,就是过不了

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1002
以下是我的源代码:
CODE:
#include<stdio.h>
#include<math.h>
#include<ctype.h>
#include<string.h>
int main(){
        int n;
        int a[1000], b[1000];
        char a1[1001], b1[1001];
       
        if (scanf("%d", &n) != EOF){
                if (n<1 || n>20) return -1;
                int tmp = 0;
                for (tmp = 1; tmp <= n;tmp++){
                        if (scanf("%s%s", a1, b1) != EOF){
                                int a_len = 0, b_len = 0;
                                a_len = strlen(a1);
                                b_len = strlen(b1);
                                int i, j;
                                for ( i = a_len - 1; i >= 0; i--){
                                        a[a_len - 1 - i] = a1[i] - '0';
                                }
                                for (j = b_len - 1; j >= 0; j--){
                                        b[b_len - 1 - j] = b1[j] - '0';
                                }

                                int max_len = (a_len > b_len) ? a_len : b_len;
                                if (a_len > b_len){
                                        int i = 0;
                                        for (i = b_len; i <= max_len; i++){
                                                b[i] = 0;
                                        }
                                        a[a_len] = 0;
                                }
                                else
                                {
                                        int j = 0;
                                        for (j = a_len; j <= max_len; j++){
                                                a[j] = 0;
                                        }
                                        b[b_len] = 0;
                                }

                                //求和
                                int k;
                                for (k= 0; k <= max_len; k++){
                                        a[k] += b[k];
                                        if (a[k] >= 10){
                                                a[k] -= 10;
                                                a[k + 1] += 1;
                                        }
                                }

                                printf("Case %d:\n%s + %s = ", tmp, a1, b1);
                                if (a[a_len] == 0){
                                        int i = 0;
                                        for (i = a_len - 1; i >= 0; i--)
                                        {
                                                printf("%d", a[i]);
                                        }
                                }
                                else{
                                        int i = 0;
                                        for (i = a_len; i >= 0; i--)
                                        {
                                                printf("%d", a[i]);
                                        }
                                }

                        }

                        if (tmp != n)
                                printf("\n\n");
                        else
                                printf("\n");

                }

        }
        return 0;

}

[ Last edited by jjdg on 2018-2-22 at 18:02 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sxhao1234

禁虫 (初入文坛)

本帖内容被屏蔽

2楼2018-02-22 15:52:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 yihang_Ren 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见