《算法笔记》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);
	} 
	
}

猜你喜欢

转载自blog.csdn.net/ling_X_super/article/details/113799948