记录编号 238427 评测结果 AAAAAATTTT
题目名称 超强的乘法问题 最终得分 60
用户昵称 GravatarGaoErFu 是否通过 未通过
代码语言 C++ 运行时间 13.320 s
提交时间 2016-03-19 08:49:34 内存使用 2.01 MiB
显示代码纯文本
#include<stdio.h>
#include<string.h>
int a[150010]={0},b[150010]={0},c[300010]={0};
char str1[150010]={0},str2[150010]={0};
int stbn(char *c,int *d)
{
	int i,j,n,k=0;
	if(c[0]=='-')k=1;
	n=strlen(c);
	memset(d,0,sizeof(int)*10000);
	for(i=n-k,j=k;i>=1,j<n;i--,j++)
	d[i]=c[j]-48;
	d[0]=n-k;
	return k;
}
void print(int *a)
{
	int i;
	for(i=a[0];i>=1;i--)
	printf("%d",a[i]);
}
void cheng(int *a,int *b,int *c)
{
	int i,j,k=1;
	memset(c,0,sizeof(int)*10000);
	for(i=1;i<=a[0];i++)
	for(j=1;j<=b[0];j++)
	{
		c[i+j-1]+=a[i]*b[j];
		c[i+j]+=c[i+j-1]/10;
		c[i+j-1]=c[i+j-1]%10;
	}
	k=a[0]+b[0];
	while(c[k]==0&&k>0)k--;
	c[0]=k;
	if(c[0]==0)c[0]=1;
}
int cc()
{
	freopen("bettermul.in","r",stdin);
	freopen("bettermul.out","w",stdout);
	int i,n1,n2;
	scanf("%s",str1);
	scanf("%s",str2);
	n1=stbn(str1,a);
	n2=stbn(str2,b);
	if(n1==0&&n2==0||n1==1&&n2==1)
	{cheng(a,b,c);print(c);}
	 if(n1==0&&n2==1||n1==1&&n2==0)
	{cheng(a,b,c);printf("-");print(c);}
	return 0;
}
int ccc=cc();
int main(){;}