正整数 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
思路:
1、本题实际上是判断一个数中的每一位,只需要循环的模 10 除 10,就能够对数的每一位进行遍历,在遍历找到所需要数的时候进行计数。
2、对 A 和 B 进行的是相同的操作,所以也可以封装成一个函数来完成,这里只需要进行两次,所以我没有使用函数的形式。
#include<stdio.h>
#include<stdlib.h>
int main()
{
int output = 0;
int num, tmp;
int A, Da, B, Db;
scanf("%d%d%d%d", &A, &Da, &B, &Db);
for (tmp = 0, num = A; num > 0; num /= 10)
{
if (num % 10 == Da)
{
tmp = tmp * 10 + Da;
}
}
output += tmp;
for (tmp = 0, num = B; num > 0; num /= 10)
{
if (num % 10 == Db)
{
tmp = tmp * 10 + Db;
}
}
output += tmp;
printf("%d\n", output);
system("pause");
return 0;
}