hdoj 1229算是简单的数字匹配吧

程序解析与优化:数字匹配与字符串转数值
本文探讨了一段程序的功能,该程序通过输入三个整数a、b和k,判断从a和b的后k位是否相同,并进行相应的数值计算或输出-1。同时,介绍了字符串转换为数值的过程,特别强调了反转字符串并在乘法操作中的应用。通过实例分析,深入理解数字匹配逻辑与字符串处理技巧。
#include<stdio.h>
#include<iostream>
using namespace std;
int main()
{
	int a,b,k;
	while(1)
	{
		scanf("%d%d%d",&a,&b,&k);
		if(a==0&&b==0)
			return 0;
		int sum=a+b;
		int flag=0;
		while(k--)
		{
			if(!a&&!b)
				break;//如果说已经除完啦。
			if(a%10!=b%10)
			{
				flag=1;break;
			}
			a/=10;b/=10;
		}
		if(flag)
			cout<<sum<<endl;
		else
			cout<<-1<<endl;
	}
	return 0;
}

/1 通过这个程序可以学到数字是如何简单匹配的。

下面是我写的程序,wa,查不到那里错啦。但那时起码学会啦字符串转化为数子的时候,要限反转在乘会很容易

 

#include<iostream>
#include<stdio.h>
#include<string>
#include<math.h>
#define MAX 8
using namespace std;
char A[MAX];char B[MAX];
int a;int b;int k;
int main()
{
	int i,j;
	//freopen("input.txt","r",stdin);
	while(1)
	{
		//初始化
		scanf("%s%s%d",A,B,&k);
		a=0;b=0;

		char newA[MAX];char newB[MAX];

		for(i=0;i<MAX;i++)
		{
			newA[i]='0';
			newB[i]='0';
		}


		if(A[0]=='0'&&B[0]=='0')
		{
			return 0;
		}

		//反转a和b
		for(i=0;i<strlen(A);i++)
		{
			newA[strlen(A)-1-i]=A[i];
		}
		for(i=0;i<strlen(B);i++)
		{
			newB[strlen(B)-1-i]=B[i];
		}

		//判断后k位是否都相同
		int same=1;
		for(i=0;i<k;i++)
		{
			if(newA[i]==newB[i])
			{
				continue;
			}
			else
			{
				same=0;break;
			}
		}

		//如果后k位相同
		if(same==1)
		{
			printf("-1\n");
		}
		else
		{
			//算出来a和b
			for(i=0;i<strlen(A);i++)
			{
				a+=(newA[i]-'0')*pow(10,i);
			}
			for(i=0;i<strlen(B);i++)
			{
				b+=(newB[i]-'0')*pow(10,i);
			}
			cout<<a+b<<endl;
		}

	}
	return 0;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值