题目:
正整数 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
分析:
无
程序:
#include <stdio.h>
long getDA(long A, long DA);
int main(){
long A, B, DA, DB;
long PA, PB;
scanf("%ld%ld%ld%ld", &A, &DA, &B, &DB);
PA = getDA(A, DA);
PB = getDA(B, DB);
printf("%ld", PA + PB);
return 0;
}
long getDA(long A, long DA)
{
long PA = 0;
do {
if (A % 10 == DA) {
PA = DA + PA * 10;
}
} while ((A = A / 10) != 0);
return PA;
}