《算法笔记》3.1小节——入门模拟->简单模拟 问题 B: A+B

问题描述:
给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号","隔开。
现在请计算A+B的结果,并以正常形式输出。

输入:
输入包含多组数据数据,每组数据占一行,由两个整数A和B组成(-10^9 < A,B < 10^9)。

输出:
请计算A+B的结果,并以正常形式输出,每组数据占一行。

样例输入:
-234,567,890 123,456,789
1,234 2,345,678

样例输出:
-111111101
2346912

思考:
首先想到了用int每读到一个逗号将前面的数乘1000加新读入的数,但处理较长数时,int类型容易存储不下,而且读入较为玛法所以考虑用字符数组,但字符数组的话,加减法得自己写函数定义,于是在网上搜索资料,然后得知了一个函数atoi (表示 ascii to integer)是把字符串转换成整型数的一个函数,得知这个函数后,这个题就比较好处理了,先用字符数组将数字读入,然后转换为int直接加减。

代码展示:

#include<cstdio>
#include<cstdlib>

void change(char *a);

int main(void)
{
	char a[20],b[20];
	while(scanf("%s %s",a,b)!=EOF)
	{
		change(a);
		change(b);
		printf("%d\n",atoi(a)+atoi(b));
	}
	return 0;
}

void change(char *a)
{
	int i,j;
	for(i=0,j=0;a[j]!=0;j++){
		if(a[j]!=',')
		{
			a[i++]=a[j];
		}
	}
	a[i]=0;
}

思考:
这次学到了atoi这个函数,然后加深了scanf读入字符串的时候会在最后加0的特点

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值