时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB
题目描述
正整数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
输出例子:
399
这道题注意一下输入数据的范围即可。
贴代码:
#include <iostream>
using namespace std;
typedef long long LL;
static void helper(LL num, LL DA, LL &PA)
{
while(num != 0)
{
if(num % 10 == DA)
{
PA = PA * 10 + DA;
}
num /= 10;
}
}
int main(void)
{
LL A, DA, B, DB;
cin>>A>>DA>>B>>DB;
LL PA = 0, PB = 0;
helper(A, DA, PA);
helper(B, DB, PB);
cout<<(PA + PB);
return 0;
}