大数相乘
发布时间:2020-12-14 03:02:23 所属栏目:大数据 来源:网络整理
导读:原文地址:http://www.voidcn.com/article/p-gumwnrcx-mw.html #include stdlib.h#include stdio.h#include string.hvoid multiply(char* a,char* b,char* c){int sa = 0;int sb = 0;int i,j;int *result = NULL;if ((NULL == a) || (NULL == b) || (NULL ==
原文地址:http://www.voidcn.com/article/p-gumwnrcx-mw.html #include <stdlib.h> #include <stdio.h> #include <string.h> void multiply(char* a,char* b,char* c) { int sa = 0; int sb = 0; int i,j; int *result = NULL; if ((NULL == a) || (NULL == b) || (NULL == c)) { return ; } sa = strlen(a); sb = strlen(b); result = (int*)malloc(sizeof(int) * (sa+sb)); //把存放结果的数组清零 //memset(result,sizeof(result)); for (i = 0; i < sa+sb; i++) { result[i] = 0; } for (i = 0; i < sa; i++) { for (j = 0; j< sb; j++) { result[i+j] += (*(a+sa-i-1) - '0') * (*(b+sb-j-1) - '0'); } } //进位 for (i = 0; i < sa+sb; i++) { result[i+1] += result[i] / 10; result[i] %= 10; } //出参赋值 i = sa+sb-1; if (result[i] == 0) { i--; } for (; i >=0; i--) { *c++ = result[i] + '0'; } *c = ' '; free(result); return ; } void main() { char *a = "52364"; char *b = "68746"; char c[100] = {0}; multiply(a,b,c); return ; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |