《算法笔记》3.1小节——入门模拟->简单模拟 部分A+B (15)

   日期:2021-02-14     浏览:93    评论:0    
核心提示:《算法笔记》3.1小节——入门模拟->简单模拟 部分A+B (15)

问题 H: 部分A+B (15)

时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述

正整数A的“DA(为1位整数)部分”定义为由A中所有DA组成的新整数PA。例如:给定A = 3862767,DA = 6,则A的“6部分”PA是66,因为A中有2个6。

现给定A、DA、B、DB,请编写程序计算PA + PB。

输入

输入在一行中依次给出A、DA、B、DB,中间以空格分隔,其中0 < A, B < 1010。

输出

在一行中输出PA + PB的值。

样例输入

3862767 6 13530293 3
3862767 1 13530293 8

样例输出

399
0

代码:

方法一:

#include<cstdio>
#include<cstring>

int main(){ 
	char a[20],b,c[20],d,e[20],f[20];
	long long A=0,B=0;
	while(scanf("%s %c %s %c",a,&b,c,&d)!=EOF){ 
	int j=0;
	for(int i=0;i<strlen(a);i++){ 
		if(a[i]==b){ 
			e[j]=a[i];
			j++;
		}
	}
	sscanf(e,"%lld",&A);
	for(int i=0;i<strlen(e);i++){ 
		e[i]='x';
	}
	j=0;
	for(int i=0;i<strlen(c);i++){ 
		if(c[i]==d){ 
			f[j]=c[i];
			j++;
		}
	}
	sscanf(f,"%lld",&B);
	
	for(int i=0;i<strlen(f);i++){ 
		f[i]='x';
	}
	
	printf("%lld\n",A+B);
	A=0,B=0;
}
	
}

方法二:

#include<cstdio>
#include<cstring>

int main(){ 
	long long a,b,da,db;
	while(scanf("%lld%lld%lld%lld",&a,&da,&b,&db)!=EOF){ 
		long long pa=0,pb=0;
		while(a!=0){ 
			if(a%10==da){ 
				pa=pa*10+da;
			}
			a/=10;
		}
		while(b!=0){ 
			if(b%10==db){ 
				pb=pb*10+db;
			}
			b/=10;
		}
		printf("%lld\n",pa+pb);
	} 
	
}
 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服