正整数 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<109。
输出格式:
在一行中输出 PA+PB 的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
/*
题目分析:
题目给的两个大整数,注意A无范围限制,但是b有
所以这里可以用字符串来输入大整数;因为这里我们需要逐位
数跟D比较,那么用字符逐个比较比用数字取余来比较更加的方便
转为数字的时候减去‘0’就可以了;
*/
#include<iostream>
#include<string>
#include<cmath>
using namespace std;
int main(){
//输入A,Da,B,Db;
string A,B;
int Da,Db;
cin>>A>>Da>>B>>Db;
int countA=0,countB=0;
int PA=0,PB=0;
//这里用countA记录Da的个数,用countB记录Db的个数;知道个数也就知道了位数;
//首先看A中Da的个数;;
for(int i=0;i<A.length();i++){
if(A[i]-'0'==Da){
countA++;
}
}
//求PA的值;
for(int i=0;i<countA;i++){
PA=PA+Da*pow(10,i); //注意这里pow要引入cmath头文件;
}
//同样看B中Db的个数;
for(int i=0;i<B.length();i++){
if(B[i]-'0'==Db){
countB++;
}
}
//求PB的值;
for(int i=0;i<countB;i++){
PB=PB+Db*pow(10,i);
}
//输出和;
cout<<PA+PB<<endl;
return 0;
}
/*
本题比较简单,就是注意用字符串比输入整数快,而且能避免整数大无法输入的情况;
*/