我对以下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;
}
答案 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;
}