PAT | 1016 部分A+B(分数 15)

博客介绍了PAT考试中的一道题目——1016 部分A+B,内容包括题目的描述、输入输出格式及样例,以及解题思路和代码实现。博主通过分析样例数据,提出利用枚举方法计算DA/DB出现的次数,以求得PA+PB的值,并讨论了数据类型的选取问题。
摘要由CSDN通过智能技术生成

活动地址: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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值