活动地址:CSDN21天学习挑战赛
PAT | 1016 部分A+B(分数 15)
题目链接:PAT | 1016 部分A+B(分数 15),作者 CHEN, Yue 单位 浙江大学
一、题目描述
正整数 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
代码长度限制 16 KB
时间限制 150 ms
内存限制 64 MB
二、分析与思考
分析样例
根据样例1输入提示,3862767中有2个6,所以组成数字PA = 66 ,13530293中有3个3,所以组成数字PB = 333,则PA+PB = 66 + 333 = 399。样例2同样如此,PA = 0,PB = 0,则 PA+PB = 0。
不难看出题目的意思,就是希望我们分析输入的数据,查找该数据中是否存在DA/DB,且计算出DA/DB出现的次数,然后根据出现的次数,不断地加权重。
例如:3个3
第一次,PB = PB + 3 * 100;
第二次,PB = PB + 3 * 101;
第三次,PB = PB + 3 * 102;
不难发现,n次时PA / PB = PA / PB + DA/DB * 10n-1
当然,3个3也可以看作是:
第一次:0 * 10 + 3 = 3;
第二次:3 * 10 + 3 = 33;
第三次: 33 * 10 + 3 = 333;
则,每出现一次DA/DB,PA / PB = PA / PB* 10 + DA/DB
关于数据类型的选择
因为0<A,B<109,在特殊情况下,PA和PB可能会超出范围,所以PA和PB可以选择长整型,其余依旧整型即可
如何分析输入的数据,计算DA/DB出现的次数
我首先想到的方法是,将整数先转换为字符串,再遍历字符串中的每一位来计算其出现的次数,但是觉得有些麻烦,主要是因为C/C++基础知识不牢,不常使用其string相关的方法,用Java的话使用该方法会简单一些。
然后看了书的提示,才反应过来,可以使用枚举的方法来实现,就是每次将数据对10除余,得到的数是数据的最后一位数,将其与DA/DB比较,相同就记录,不同则跳过。
三、代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int a, b, Da, Db;
long long Pa = 0, Pb = 0;
cin >> a >> Da >> b >> Db;
while(a != 0) {
if(a % 10 == Da) {
Pa = Pa * 10 + Da;
}
a /= 10;
}
while(b != 0) {
if(b % 10 == Db) {
Pb = Pb * 10 + Db;
}
b /= 10;
}
cout << Pa + Pb << endl;
return 0;
}