正整数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的值。
输入样例1:
3862767 6 13530293 3
输出样例1:
399
输入样例2:
3862767 1 13530293 8
输出样例2:
0
本来试图用字符串去接收长数组,但是出现了两个测试点的错误,换了一种方法试试。。就成了。
// 3862767 6 13530293 3
#include<iostream>
#include<string>
using namespace std;
/*
long GetNew1(const string orinumber, int seeknumber)
{
int number=0;
int i=0;
while (i!=string::npos)
{
i = i + 1;
i=orinumber.find('0' + seeknumber, i);
//去数组中发现i个6.
if (i != string::npos)number = number * 10 + seeknumber;
}
return number;
}*/
long GetNew(long A, long DA)
{
int pA = 0;
while (A!=0)
{
if (A%10==DA)
{
pA = 10 * pA + DA;
}
A = A / 10;
}
return pA;
}
int main()
{
long pA, pB;
long A, B;
cin >> A >> pA;
cin >> B >> pB;
cout << GetNew(A, pA)+GetNew(B,pB)<<endl;
system("pause");
return 0;
}