【高精度】简单高精度减法

问题 C: 【高精度】简单高精度减法

时间限制: 1 Sec  内存限制: 64 MB

题目描述

邪狼掌握了简单高精度加法程序的编写后,修罗王要求邪狼写一个简单高精度减法的程序。即求出A-B的值,其中A和B均为非负整数,其位数不超过5000。

 

输入

共两行数据,第一行为一个非负整数A,第二行为一个非负整数B,A、B的位数均在5000以内。

 

输出

输出一个整数,即A-B的值。

 

样例输入

复制样例数据

2
1

样例输出

1

注意a可能小于b

/**/
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cctype>
#include <iostream>
#include <algorithm>
#include <map>
#include <set>
#include <vector>
#include <string>
#include <stack>
#include <queue>

typedef long long LL;
using namespace std;

char a[5005], b[5005], c[5005], d[5005];
int ans[5005];

bool judge(char a[], char b[]){
	int len1 = strlen(a), len2 = strlen(b);
	if(len1 < len2) return 1;
	if(len1 == len2){
		for (int i = 0; i < len1; i++){
			if(a[i] < b[i]){
				return 1;
			}else if(a[i] > b[i]) return 0;
		}
	}
	return 0;
}

int main()
{
	//freopen("in.txt", "r", stdin);
	//freopen("out.txt", "w", stdout);

	scanf("%s %s", c, d);
	int flag = 0;
	if(judge(c, d) == 1){ // c<d
		memcpy(a, d, sizeof(d)), memcpy(b, c, sizeof(c));
		flag = 1;
	}else{
		memcpy(b, d, sizeof(d)), memcpy(a, c, sizeof(c));
	}
	int lena = strlen(a), lenb = strlen(b);
	int cnt = 0;
	while(lenb - cnt > 0){
		if(a[lena - cnt - 1] - b[lenb - cnt - 1] >= 0){
			ans[cnt] = a[lena - cnt - 1] - b[lenb - cnt - 1];
		}else{
			int t = 1;
			while(a[lena - cnt - 1 - t] == '0'){ //哎!!
				a[lena - cnt - 1 - t] = '9';
				t++;
			}
			a[lena - cnt - 1 - t]--;
			ans[cnt] = a[lena - cnt - 1] - b[lenb - cnt - 1] + 10;
		}
		cnt++;
	}
	while(lena - cnt > 0){
		ans[cnt] = a[lena - cnt - 1] - '0';
		cnt++;
	}
	while(ans[cnt] == 0 && cnt > 0) cnt--;
	if(flag) printf("-");
	for (int i = cnt; i >= 0; i--){
		printf("%d", ans[i]);
	}
	printf("\n");

	return 0;
}
/**/

 

全部评论

相关推荐

10-27 17:26
东北大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务