大数问题

By MLTech

昨天瞌睡状态下写了一下大数相乘,各种低级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
//BigDataMultifly.c

#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]; //此处本来用char c[alen+blen+1],无奈OJ不通过本地测试通过。

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;
}