昨天瞌睡状态下写了一下大数相乘,各种低级bug,类型转换、参数写错、少写语句。。刚刚又写了一下。直接贴代码吧,写出来之后去poj2389跑了下过了。不过我发现,如果声明数组的时候size是变量(char c[clen]),在oj上会编译出错啊。但是sublime下没有这个问题。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
#include <stdio.h> #include <string.h> int main() { char a[42],b[42]; scanf("%s",a); scanf("%s",b);
int alen=strlen(a), blen=strlen(b), clen=alen+blen; char c[84];
memset(c,'0',sizeof(c));
int i=alen-1,j=blen-1,tmp=0,pre=0,k=0; for(i=alen-1;i>=0;i--) { for(j=blen-1;j>=0;j--) { k=0; tmp = (a[i]-'0')*(b[j]-'0'); while(1) { if(c[i+j+1-k]-'0' + tmp > 9) { pre = (c[i+j+1-k]-'0' + tmp)/10; c[i+j+1-k] = ((c[i+j+1-k]-'0' + tmp) % 10)+'0'; k++; tmp=pre; } else { c[i+j+1-k] = (c[i+j+1-k]-'0' + tmp) +'0'; break; } } } }
i=0; while(c[i]=='0') i++; for(;i<clen;i++) printf("%c", c[i]); return 0; }
|