九度oj 题目1015:还是A+B 【ZJU2006考研机试题1】

本文详细解析了九度在线判题系统中题目1015的A+B问题,该题目源自2006年浙江大学考研机试真题。内容涵盖如何处理两个整数相加的算法及可能遇到的边界条件,适合编程初学者和备考者复习巩固基础。
摘要由CSDN通过智能技术生成

题目1015:还是A+B

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:3226

解决:2004

题目描述:
读入两个小于10000的正整数A和B,计算A+B。需要注意的是:如果A和B的末尾K(不超过8)位数字相同,请直接输出-1。
输入:

测试输入包含若干测试用例,每个测试用例占一行,格式为"A B K",相邻两数字有一个空格间隔。当A和B同时为0时输入结束,相应的结果不要输出。

输出:

对每个测试用例输出1行,即A+B的值或者是-1。

样例输入:
1 2 1
11 21 1
108 8 2
36 64 3
0 0 1
样例输出:
3
-1
-1
100
来源:
2006年浙江大学计算机及软件工程研究生机试真题
答疑:
解题遇到问题?分享解题心得?讨论本题请访问: http://t.jobdu.com/thread-7739-1-1.html

法一:模 运算

/*  
	1.巧用 模 事半功倍   2.a^b次方,即 pow(a,b);
*/	
#include<stdio.h>
#include<math.h>
int main()
{
	int n,m,k;
	while(scanf("%d %d %d",&n,&m,&k)!=EOF){
		if(n==0&&m==0)
			break;
		int tmp=pow(10,k);
		if(m%tmp==n%tmp)
			printf("-1\n");
		else
			printf("%d\n",n+m);	
	}
	return 0;
}


法二:把数字 存成数位

/*  
    1.字符串必须要用strcpy()进行比较!!!别犯低级错误。。。。。
	2.数组下标不是从0开始的话,要注意当有0个的情况,是否需要跳过,不然可能 会越界 或 产生错误结果。
*/	
#include<stdio.h>

const int MAX=20;
int a[MAX],b[MAX];
int size1,size2;
void num2Dig(int x,int y)
{
	size1=0;size2=0;
	int i;
	for(i=0;i<MAX;i++){  //108,8比较后两位是否一样,显然是一样:8前面要补0,不妨让初始化时自动补好0,默认是负无穷大。
		a[i]=0;
		b[i]=0;
	}
	do{
		a[size1++]=x%10;
		x=x/10;
	}while(x!=0);
	do{
		b[size2++]=y%10;
		y=y/10;
	}while(y!=0);
}
int main()
{
	int n,m,k,i;
	//freopen("G:\\in.txt","r",stdin);
	//freopen("G:\\our.txt","w",stdout);
	while(scanf("%d %d %d",&n,&m,&k)!=EOF){
		if(n==0&&m==0)
			break;
		num2Dig(n,m);
		bool iSame=1;
		for(i=0;i<k;i++){
			if(a[i]!=b[i]){
				iSame=0;
				break;
			}
		}
		if(iSame)
			printf("-1\n");
		else
			printf("%d\n",n+m);	
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值