0
已解决
张舒斌
中级光能
中级光能
#include<bits/stdc++.h>
using namespace std;
int a[10000],b[10000],c[10000000];
string s1,s2;
void chengfa()
{
memset(c,0,sizeof(c));
c[0]=a[0]+b[0];
int jw;
for(int i=1;i<=a[0];i++)
{
jw=0;
for(int j=1;j<=b[0];j++)
{
c[i+j-1]+=a[i]*b[j]+jw;
jw=c[i+j-1]/10;
c[i+j-1]%=10;
}
c[i+b[0]]+=jw;
}
while(c[c[0]]==0&&c[0]!=1) c[0]--;
}
void jiafa()
{
memset(c,0,sizeof(c));
c[0]=max(a[0],b[0]);
int jw=0;
for(int i=1;i<=c[0];i++)
{
c[i]=a[i]+b[i]+jw;
jw=c[i]/10;
c[i]%=10;
}
if(jw!=0)
{
c[c[0]]=jw;
c[0]++;
}
}
void jianfa()
{
memset(c,0,sizeof(c));
c[0]=a[0];
for(int i=1;i<=c[0];i++)
{
if(a[i]<b[i])
{
a[i]+=10;
a[i+1]--;
}
c[i]=a[i]-b[i];
}
while(c[c[0]]==0&&c[0]!=1)
{
c[0]--;
}
}
int main()
{
int n;
cin>>n;
char ysf;
for(int i=1;i<=n;i++)
{
cin>>s1>>s2>>ysf;
a[0]=s1.size();
b[0]=s2.size();
for(int i=1;i<=a[0];i++)
{
a[i]=s1[a[0]-i]-48;
}
for(int i=1;i<=b[0];i++)
{
b[i]=s2[b[0]-i]-48;
}
if(ysf=='+')
{
jiafa();
}
else if(ysf=='-')
{
jianfa();
}
else if(ysf=='*')
{
chengfa();
}
for(int i=c[0];i>=1;i--)
{
cout<<c[i];
}
memset(c,0,sizeof(c));
cout<<endl;
}
return 0;
}
@陆麟瑞
张舒斌在2018-08-10 21:32:04追加了内容
题号:2743大数运算