大数乘法 可调用
发布时间:2020-12-14 04:04:04 所属栏目:大数据 来源:网络整理
导读:#includestdio.h#includestring.h#includestdlib.h#define Max 2000void multiply(char *a,char *b,char *c){ int i,j,lena,lenb,*s; lena=strlen(a); lenb=strlen(b); s=(int*)malloc(sizeof(int)*(lena+lenb)); for (i=0;ilena+lenb;i++) s[i]=0; for (i=0
#include<stdio.h> #include<string.h> #include<stdlib.h> #define Max 2000 void multiply(char *a,char *b,char *c) { int i,j,lena,lenb,*s; lena=strlen(a); lenb=strlen(b); s=(int*)malloc(sizeof(int)*(lena+lenb)); for (i=0;i<lena+lenb;i++) s[i]=0; for (i=0;i<lena;i++) for (j=0;j<lenb;j++) s[i+j+1]+=(a[i]-'0')*(b[j]-'0'); for (i=lena+lenb-1;i>=0;i--) if (s[i]>=10) { s[i-1]+=s[i]/10; s[i]%=10; } i=0; while (s[i]==0) i++; if(i>lena+lenb-1) strcpy(c,"0"); else { for (j=0;i<lena+lenb;i++,j++) c[j]=s[i]+'0'; c[j]=' '; } free(s); } int main() { char a[200],b[200],c[200]; while(scanf("%s%s",a,b)!=EOF) { multiply(a,b,c); puts(c); } return 0; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |