无敌小霸王782 2021-11-27 14:03 采纳率: 83.3%
浏览 17
已结题

为什么我的在编译器上对了,但在落谷上就全是wrong呢

#include <stdio.h>
#include <string.h>

int compute (int i) {
int count = 0;
if (i <= 0) {
count++;
}
while (i) {
i /= 10;
count++;
}

return count;

}

int main () {
int n, i, t, j, count;
scanf("%d", &n);
char a[51][100];
int b[51][100] = {0};
getchar();
for (i = 0; i < n; i++) {
gets(a[i]);
}
for (i = 0; i < n; i++) {
count = 1;
for (j = 0; j < strlen(a[i]); j++) {
if (a[i][0] != 'a' && a[i][0] != 'b' && a[i][0] != 'c') {
if (a[i][j] == ' ') {
count = 2;
continue;
}
b[i][count] = b[i][count] * 10 + (a[i][j] - 48);

        } else {
            if (j == 0) {
                j += 2;
            }
            if (a[i][j] == ' ') {
                count = 2;
                continue;
            }
            b[i][count] = b[i][count] * 10 + (a[i][j] - 48);

        }
    }
}


for (i = 0; i < n ; i++) {
    if (a[i][0] == 'a') {
        printf("%d+%d=%d\n", b[i][1], b[i][2], b[i][1] + b[i][2]);
        printf("%d\n", 2 + compute(b[i][1]) + compute(b[i][2]) + compute(b[i][1] + b[i][2]));
    } else if (a[i][0] == 'b') {
        printf("%d-%d=%d\n", b[i][1], b[i][2], b[i][1] - b[i][2]);
        printf("%d\n", 2 + compute(b[i][1]) + compute(b[i][2]) + compute(b[i][1] - b[i][2]));
    } else if (a[i][0] == 'c') {
        printf("%d*%d=%d\n", b[i][1], b[i][2], b[i][1]*b[i][2]);
        printf("%d\n", 2 + compute(b[i][1]) + compute(b[i][2]) + compute(b[i][1]*b[i][2]));
    } else  if (a[i][0] > '0' && a[i][0] <= '9') {
        if (a[i - 1][0] == 'a') {
            printf("%d+%d=%d\n", b[i][1], b[i][2], b[i][1] + b[i][2]);
            printf("%d\n", 2 + compute(b[i][1]) + compute(b[i][2]) + compute(b[i][1] + b[i][2]));
        }
        if (a[i - 1][0] == 'b') {
            printf("%d-%d=%d\n", b[i][1], b[i][2], b[i][1] - b[i][2]);
            printf("%d\n", 2 + compute(b[i][1]) + compute(b[i][2]) + compute(b[i][1] - b[i][2]));
        }
        if (a[i - 1][0] == 'c') {
            printf("%d*%d=%d\n", b[i][1], b[i][2], b[i][1]*b[i][2]);
            printf("%d\n", 2 + compute(b[i][1]) + compute(b[i][2]) + compute(b[i][1]*b[i][2]));
        }
    }
}







return 0;

}

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2021-11-27 14:05
    关注

    比如题目可能要求输出没有空行。你这所有printf都带\n可能就不行了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月7日
  • 已采纳回答 11月29日
  • 创建了问题 11月27日

悬赏问题

  • ¥15 wegame打不开英雄联盟
  • ¥15 公司的电脑,win10系统自带远程协助,访问家里个人电脑,提示出现内部错误,各种常规的设置都已经尝试,感觉公司对此功能进行了限制(我们是集团公司)
  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多