正整数 A 的“
D
A
D_A
DA(为 1 位整数)部分”定义为由
A
A
A 中所有
D
A
D_A
DA 组成的新整数
P
A
P_A
PA。例如:给定
A
A
A=3862767,
D
A
D_A
DA=6,则
A
A
A 的“6 部分”
P
A
P_A
PA 是 66,因为
A
A
A 中有 2 个 6。
现给定
A
A
A、
D
A
D_A
DA、
B
B
B、
D
B
D_B
DB,请编写程序计算
P
A
P_A
PA+
P
B
P_B
PB。
输入格式:
输入在一行中依次给出 A A A、 D A D_A DA、 B B B、 D B D_B DB,中间以空格分隔,其中 0 < A , B < 1 0 10 0<A,B<10^{10} 0<A,B<1010。
输出格式:
在一行中输出 P A P_A PA+ P B P_B PB 的值。
输入样例1:
3862767 6 13530293 3
输出样例1:
399
输入样例2:
3862767 1 13530293 8
输出样例2:
0
解题思路:
保存 A A A为字符串,枚举字符串的每一位,匹配关键字 D A D_A DA,匹配成功则用公式 P A = P A ∗ 10 + D A P_A = P_A*10 + D_A PA=PA∗10+DA计算,字符串 B B B同理。
答案代码:
#include <iostream>
#include <string>
using namespace std;
int search(string s, int key) {
int num = 0;
for (int i = 0; i != s.size(); i++) { // 枚举字符串每一位
if (s[i] - '0' == key) // 匹配关键字
num = num*10 + key;
}
return num;
}
int main() {
string a, b;
int da = 0, db = 0, m =0, n = 0;
cin >> a >> da >> b >> db;
m = search(a, da);
n = search(b, db);
cout << m + n << endl;
return 0;
}