[PAT解题报告] 部分A+B (15)

转载 from http://tech-wonderland.net/blog/pat-basic-level-practice-1016-1020-solutions.html

解题思路: 就是给定两个数字以及分别给出一个个位整数, 从这两个数种抽出只含有这个个位整数的部分, 相加求和. 注意用long long 存结果以及计算, 貌似int存不下. 下面是AC代码:
#include <string>
#include <iostream>

long long extractPNumber(const std::string str, int d) {
    int len = str.size();
    long long itr = 1;
    long long res = 0;
    for(int i = 0; i < len; ++i) {
        if(str[i] - '0' == d) {
            res += d * itr;
            itr *= 10;
        }
    }
    return res;
}

int main() {
    std::string A, B;
    int Da, Db;

    std::cin >> A >> Da >> B >> Db;
    std::cout << extractPNumber(A, Da) + extractPNumber(B, Db) << std::endl;

    return 0;
}

全部评论
能不能不装逼,好好写个代码。。。。。。
点赞 回复 分享
发布于 2016-01-20 19:38
int可以存下,不是貌似存不下
点赞 回复 分享
发布于 2016-01-27 09:15
不知道是谁水平有限。。
点赞 回复 分享
发布于 2016-06-24 20:35
为何不用using namespace:std;呢
点赞 回复 分享
发布于 2015-09-30 04:43
看到这代码,我只想说有多少人能看懂?还不如直接用pascal写呢,看懂的人更少,更能显出作者水平。。。。。。
点赞 回复 分享
发布于 2016-01-20 19:36
感觉写的不错啊,很简洁,少而精,为什么会有人喷。。。不理解。
点赞 回复 分享
发布于 2016-01-26 11:09
按理说int类型不可以,假如输入的是(十个9、9、十个9、9)这四个数,最后会溢出吧,但在这题上用int却没问题,谁知道这是怎么回事?
点赞 回复 分享
发布于 2017-12-21 20:38
arr=input().split() lst1=list(arr[0]) lst2=list(arr[2]) a=lst1.count(arr[1]) b=lst2.count(arr[3]) print(int(arr[1]*a)+int(arr[3]*b)) 有两个测试用例不成功大神帮我看一下
点赞 回复 分享
发布于 2018-09-13 19:33

相关推荐

一名愚蠢的人类:多少games小鬼留下了羡慕的泪水
投递荣耀等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务