c语言给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。
时间: 2024-06-13 09:06:03 浏览: 115
以下是C语言实现给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式的代码:
```c
#include <stdio.h>
#include <string.h>
char* multiply(char* num1, char* num2) {
int len1 = strlen(num1), len2 = strlen(num2);
int len = len1 + len2;
int i, j, k, carry, n1, n2, sum;
char* res = (char*)malloc(sizeof(char) * (len + 1));
memset(res, '0', len + 1);
for (i = len1 - 1; i >= 0; i--) {
carry = 0;
n1 = num1[i] - '0';
for (j = len2 - 1; j >= 0; j--) {
n2 = num2[j] - '0';
sum = n1 * n2 + carry + (res[i + j + 1] - '0');
carry = sum / 10;
res[i + j + 1] = sum % 10 + '0';
}
res[i + j + 1] += carry;
}
for (i = 0; i < len; i++) {
if (res[i] != '0') {
break;
}
}
if (i == len) {
res[1] = '\0';
return res;
}
return res + i;
}
int main() {
char num1[] = "123";
char num2[] = "456";
char* res = multiply(num1, num2);
printf("%s\n", res);
free(res);
return 0;
}
```
阅读全文