PTA | 程序设计类实验辅助教学平台 (pintia.cn)
正整数 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<109。
输出格式:
在一行中输出 PA+PB 的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
#include<iostream>
#include<cmath>
#include <vector>
#include <map>
#include<utility>
#include <algorithm>
#include<string>
using namespace std;
int main() {
string a,b;
char a1, b1;
cin >> a>>a1>>b>>b1;
int a_length,b_length;
a_length = a.size();
b_length = b.size();
string a2,b2;
for (int i = 0; i <a_length; i++) {
if (a[i] == a1)a2 += a1;
}
for (int i = 0; i < b_length; i++) {
if (b[i] == b1)b2 += b1;
}
int sum1 = 0;
int i = 0;
while (isdigit(a2[i]))//判断是不是数字
sum1 = sum1 * 10 + a2[i++] - '0';//转整形
int sum2 = 0;
i = 0;
while (isdigit(b2[i]))//判断是不是数字
sum2 = sum2 * 10 + b2[i++] - '0';//转整形
int ans=0;
ans = sum1 + sum2;
cout << ans;
}