PAT 乙级 1016.部分A+B C++/Java
作者:互联网
正整数 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
思路:
先分别找出DA、DB在A、B中出现的次数countA、countB,再分别得出整数PA、PB,输出两者和即可。
C++实现:
#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; }
Java实现:
标签:PAT,int,DB,C++,DA,++,Java,resA,countA 来源: https://www.cnblogs.com/47Pineapple/p/14613747.html