#include<bits/stdc++.h>
using namespace std;
int x[165000001],y[165000001],z[165000001];
char c[165000001];
void input(int a[])
{
cin>>c;
int len=strlen(c);
if(c[0]=='-')
{
for(int i=1;i<len;i++)
a[len-i]=c[i]-'0';
a[len]=-1;
len--;
}
else
for(int i=0;i<len;i++)
a[len-i]=c[i]-'0';
a[0]=len;
for(int i=a[0]; i>0&&a[i]==0; a[0]--,i--);
a[a[0]+1]=a[len+1];
}
void output(int a[])
{
if(a[a[0]+1]==-1)
cout<<"-";
for(int i=a[0];i>=1;i--)
cout<<a[i];
cout<<endl;
}
bool less_than(int a[],int b[])
{
if(a[0]!=b[0])
return a[0]<b[0];
for(int i=a[0];i>=1;i--)
if(a[i]!=b[i])
return a[i]<b[i];
return false;
}
void sub1(int c[],int a[],int b[])
{
c[0]=a[0]>b[0]?a[0]:b[0];
bool LE=less_than(a,b);
if(!LE)
for(int i=1;i<=c[0];i++)
{
if(a[i]<b[i])
{
a[i+1]--;
a[i]+=10;
}
c[i]=a[i]-b[i];
}
else
for(int i=1;i<=c[0];i++)
{
if(b[i]<a[i])
{
b[i+1]--;
b[i]+=10;
}
c[i]=b[i]-a[i];
}
while(c[c[0]]==0)
c[0]--;
if(c[0]==0)
c[0]=1;
if(LE)
c[c[0]+1]=-1;
}
void sub2(int c[],int a[],int b[])
{
c[0]=a[0]>b[0]?a[0]:b[0];
for(int i=1;i<=c[0];i++)
c[i]=a[i]-b[i];
int len=c[0];
while(c[len]==0)
len--;
if(len==0)
len=1;
if(c[len]<0)
{
c[len+1]=-1;
for(int i=len;i>=1;i--)
c[i]*=-1;
}
for(int i=1;i<=len;i++)
if(c[i]<0)
{
c[i]+=10;
c[i+1]-=1;
}
int sign=len+1;
while(c[len]==0)
len--;
if(len==0)
len=1;
else
c[len+1]=c[sign];
c[0]=len;
}
int main()
{
input(x);
input(y);
sub1(z,x,y);
output(z);
}
测评记录