[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

相关推荐

沉淀一会:1.同学你面试评价不错,概率很大,请耐心等待; 2.你的排名比较靠前,不要担心,耐心等待; 3.问题不大,正在审批,不要着急签其他公司,等等我们! 4.预计9月中下旬,安心过节; 5.下周会有结果,请耐心等待下; 6.可能国庆节前后,一有结果我马上通知你; 7.预计10月中旬,再坚持一下; 8.正在走流程,就这两天了; 9.同学,结果我也不知道,你如果查到了也告诉我一声; 10.同学你出线不明朗,建议签其他公司保底! 11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务