大数运算(二)——大数相减
发布时间:2020-12-14 02:20:12 所属栏目:大数据 来源:网络整理
导读:输入两行字符串整数,第一行是被减数,第二行是减数,输出第一行减去第二行的结果。 备注:1.两个整数都是正整数,被减数大于减数 示例: 输入:100000000001 1 输出:100000000000 #includeiostream #includestring using namespace std ; void BigSub( str
输入两行字符串整数,第一行是被减数,第二行是减数,输出第一行减去第二行的结果。备注:1.两个整数都是正整数,被减数大于减数 #include<iostream>
#include<string>
using namespace std;
void BigSub(string a,string b)
{
if(a==b)
{
cout<<"0"<<endl;
return;
}
int singnal=0;
int len1=a.size();
int len2=b.size();
if(len1<len2 || len1==len2 && a<b)
{
string c=a;
a=b;
b=c;
singnal=1;
}
int i,n=len1-len2;
for(i=len2-1;i>=0;i--)
a[len1-1-i]='0'+a[len1-1-i]-b[len2-1-i];
for(i=len1-1;i>=0;i--)
{
if(a[i]<'0')
{
a[i] +=10;
a[i-1]--;
}
}
i=0;
while('0'==a[i])
i++;
a.erase(0,i);
if(singnal)
a='-'+a;
cout<<a<<endl;
}
int main()
{
string str1,str2;
while(cin>>str1>>str2)
BigSub(str1,str2);
}
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |