如何修复以下C程序的输出?

时间:2019-01-06 21:11:08

标签: c string

我对以下C程序的输出有疑问。它没有为我提供正确的输出。我从两个大数之和转换了该程序。 所以我得到的输出带有一些“错误”,例如“ 232423-3-4-34--3424”,而不是“ 23242334343424”。我该如何解决?

 #include<stdio.h>
int main() {
  int num1[255], num2[255], dif[255];
  char s1[255], s2[255];
  int l1, l2;

  printf("Enter Number1:\n");
  scanf("%s", &s1);
  printf("Enter Number2:\n");
  scanf("%s", &s2);

  for (l1 = 0; s1[l1] != '\0'; l1++)
    num1[l1] = s1[l1] - '0';

  for (l2 = 0; s2[l2] != '\0'; l2++)
    num2[l2] = s2[l2] - '0';

  int carry = 0;
  int k = 0;
  int i = l1 - 1;
  int j = l2 - 1;
  for (; i >= 0 && j >= 0; i--, j--, k++) {
    dif[k] = (num1[i] - num2[j] - carry) % 10;
    carry = (num1[i] - num2[j] - carry) / 10;
  }
  if (l1 > l2) {

    while (i >= 0) {
      dif[k++] = (num1[i] - carry) % 10;
      carry = (num1[i--] - carry) / 10;
    }

  } else if (l1 < l2) {
    while (j >= 0) {
      dif[k++] = (num2[j] - carry) % 10;
      carry = (num2[j--] - carry) / 10;
   }
  } else {
    if (carry > 0)
      dif[k++] = carry;
  }


  printf("Result:");
  for (k--; k >= 0; k--)
    printf("%d", dif[k]);

  return 0;
}

1 个答案:

答案 0 :(得分:3)

您的结果包含负数,因为该代码未正确实现10模运算。在这样的行中:

dif[k] = (num1[i] - num2[j] - carry) % 10;

如果减法num1[i] - num2[j] - carry小于0,则要存储10减法的结果。在某些语言中,%运算符works与此类似,但是在C中它返回负数,因此-1 % 10产生-1而不是9。

要解决此问题,代码需要更明确,例如:

int sub = num1[i] - num2[j] - carry;
if (sub >= 0) {
    dif[k] = sub;
    carry = 0;
} else {
    dif[k] = 10 - sub;
    carry = 1;
}