【c++】大整数减法模板

思路:

  • 设所求为a-b,模拟手工减法
  • a,b长度需要对齐
  • a=b时输出0
  • a<b时首先输出负号,然后输出b-a的值
  • a>b时输出a-b的值
  • 需注意借位

样例输入:

1-2

4-3

6-6

样例输出:

-1

1

0

代码:

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
bool bigger(string a,string b){//判断a>b的布尔值 
	if(a.size()!=b.size()) return a.size()>b.size();
	for(int i=0;i<a.size();i++){
		if(a[i]!=b[i]) return a[i]>b[i];
	}
	return true;
}
void solve(string a,string b){//减法处理
	if(a==b){//如果a=b不需要减法,结果为0 
		cout<<"0\n";
		return ;
	}
	bool fu=bigger(a,b);//判断结果是否为负数 
	if(!fu){//负数输出负号 
		cout<<'-';
		swap(a,b);
	}
	while(b.size()<a.size()){//字符串长度对齐 
		b="0"+b;
	}
	for(int i=a.size()-1;i>=0;i--){
		if(a[i]<'0'||a[i]<b[i]){//不足借位 
			a[i-1]--;
			a[i]+=10;
		}
		a[i]-=b[i]-'0';//对应位相减 
	}
	cout<<a<<endl;//输出 
}
int main(){
    string a,b;
    while(cin>>a){
    	b="";
	    int f=0;
	    for(f;a[f]!='-';f++);//分割字符串 
	    for(int i=1;f+i<a.size();i++){
	        b+=a[f+i];
	    }
	    a.erase(a.begin()+f,a.end());//删除a中-以后的部分 
	    solve(a,b);
	}
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cout0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值