3115 高精度练习之减法


解法一

[解题思路]

    把输入的数字以字符串的形式存储,转变为对字符串的处理,注意对负数,没有意义的0的处理。

[代码实现]

#include<iostream>
#include<string>
using namespace std;
int main()
{
    string a,b;
	cin>>a>>b;
	if (a.size()<b.size()||(a.size()==b.size()&&a<b))  /* 保证a>b */
	{
		swap(a,b);
		cout<<"-";
	}
	for (int i=1;i<=b.size();i++)
	{
		a[a.size()-i]=a[a.size()-i]-b[b.size()-i]+'0'; /*从个位减起,每一位简单相减*/
	}
	for (int i=1;i<=a.size();i++)
	{
		if (a[a.size()-i]<'0')          /*退位*/  
		{
			a[a.size()-i-1]-=1;
    		a[a.size()-i]+=10;
		}
	}
	int book;
	for (book=0;book<a.size();book++)      /*对没有意义的0的处理*/
	{
		if(a[book]!='0')  break;
	}
	for (int i=book;i<a.size();i++)
	{
		if (a[i]>='0'&&a[i]<='9')  
			cout<<a[i];
	}
	return 0;
}
解法二
[解题思路]

把输入的数字a和b以字符串的形式存储,再把a和b的每一位数字逆序转换为int形式存在动态申请的ia和ib数组。比较a和b两者的大小,保证a>b,再把ia和ib的每一位数字相减存在较大的数组中。

[代码实现]

       

#include<iostream>
#include<string>
using namespace std;
int main()
{
	string a,b;
	cin>>a>>b;
	int a_size=a.size(), b_size=b.size();
	int size=a_size>b_size?a_size:b_size;
	/* 注意a和b数组申请的大小为size */
	int *ia=new int[size];
	int *ib=new int[size];      
	/* 初始化 */
	for (int i=0;i<size;i++)		
		ia[i]=ib[i]=0;
	/* 逆序存储 */
	for (int i=0;i<a_size;i++)   ia[a_size-i-1]=a[i]-'0';	
	for (int i=0;i<b_size;i++)   ib[b_size-i-1]=b[i]-'0';	
	/* 保证a>b */
	if(a_size<b_size || a_size == b_size && a<b)
	{
		swap(ia,ib);
		cout<<"-";
	}
	/* 因为逆序,所以i=0是从个位减起 */
	for (int i=0;i<size;i++)       
	{
		ia[i]=ia[i]-ib[i];
	}
	/*退位*/
	for (int i=0;i<size-1;i++)     
	{
		
		if(ia[i]<0)
		{
			ia[i+1]-=1;
			ia[i]+=10;
		}
	}
	/*不打印无意义的0*/
	int book=0;
	for (book=size-1;book>=0;book--)
	{
		if(ia[book])
			break;
	}
	for (int i=book;i>=0;i--)
	{
		cout<<ia[i];
	}
	return 0;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值