无敌小霸王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 ogg dd trandata 报错
  • ¥15 高缺失率数据如何选择填充方式
  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错