【问题描述】
正整数A的“DA(为1位整数)部分”定义为由A中所有DA组成的新整数PA。例如:给定A = 3862767,DA = 6,则A的“6部分”PA是66,因为A中有2个6;给定A = 3862767,DA = 1,则A的“1部分”PA是0,因为A中有0个1。
现给定A、DA、B、DB,请编写程序计算PA + PB。
【输入形式】
输入在一行中依次给出A、DA、B、DB,中间以空格分隔,其中0 < A, B < 1010。
【输出形式】
在一行中输出PA + PB的值。
【样例输入】
3862767 6 13530293 3
【样例输出】
399
#include<iostream>
#include<string>
using namespace std;
int main()
{
string a,b;
char da,db;
cin>>a>>da>>b>>db;
int lena=a.length();
int lenb=b.length();
int na=0,nb=0;
for(int i=0;i<lena;i++)
{
if(a[i]==da) na++;
}
for(int i=0;i<lenb;i++)
{
if(b[i]==db) nb++;
}
int DA=int(da)-48;
int DB=int(db)-48;
int pa=0,pb=0;
for(int i=1;i<=na;i++)
{
pa=pa*10+DA;
}
for(int i=1;i<=nb;i++)
{
pb=pb*10+DB;
}
int sum=pa+pb;
cout<<sum;
return 0;
}