正整数 A 的“D?A??(为 1 位整数)部分”定义为由 A 中所有 D?A?? 组成的新整数 P?A??。例如:给定 A=3862767,D?A??=6,则 A 的“6 部分”P?A?? 是 66,因为 A 中有 2 个 6。
现给定 A、D?A??、B、D?B??,请编写程序计算 P?A??+P?B??。
输入在一行中依次给出 A、D?A??、B、D?B??,中间以空格分隔,其中 0 < A, B < 1010。
在一行中输出P?A??+P?B??的值。
3862767 6 13530293 3
399
3862767 1 13530293 8
0
先分别找出DA、DB在A、B中出现的次数countA、countB,再分别得出整数PA、PB,输出两者和即可。
#include <iostream> using namespace std; int main() { string A, B; char DA, DB; int countA = 0, countB = 0; cin >> A >> DA >> B >> DB; for (int i = 0; i < A.length(); i++) { if (A[i] == DA) { countA++; } } for (int i = 0; i < B.length(); i++) { if (B[i] == DB) { countB++; } } int resA = 0, resB = 0; for (int i = 0; i < countA; i++) { int rA = DA - ‘0‘; resA = resA * 10; resA += rA; } for (int i = 0; i < countB; i++) { int rB = DB - ‘0‘; resB = resB * 10; resB += rB; } cout << resA + resB << endl; }
原文:https://www.cnblogs.com/47Pineapple/p/14613747.html