PAT乙级 b1016

1016 部分A+B (15)(15 分)

正整数A的“D~A~(为1位整数)部分”定义为由A中所有D~A~组成的新整数P~A~。例如:给定A = 3862767,D~A~ = 6,则A的“6部分”P~A~是66,因为A中有2个6。

现给定A、D~A~、B、D~B~,请编写程序计算P~A~ + P~B~。

输入格式:

输入在一行中依次给出A、D~A~、B、D~B~,中间以空格分隔,其中0 < A, B < 10^10^。

输出格式:

在一行中输出P~A~ + P~B~的值。

输入样例1:

3862767 6 13530293 3

输出样例1:

399

输入样例2:

3862767 1 13530293 8

输出样例2:

0

扫描二维码关注公众号,回复: 2427151 查看本文章

思路:

该题涉及到枚举算法  即通过把输入的内容 通过枚举法 一个一个 比较 符合条件则 进行处理tips : 如何进行整数的枚举呢  取余是一个思路那如果是字符串呢  如何让枚举 可以想一想 

code:

#include<cstdio>

int main ()

{

    long long a,b,da,db;

    scanf ("%lld%d%lld%d",&a,&da,&b,&db);

    long long pa = pb = 0;

    while (a != 0 && a % 10 == da )//枚举a的每一位数 并作比较

    {

        pa = pa * 10 + da;

        a = a / 10;

    }

    while (b != 0 && b % 10 == db )//枚举b的每一位数 并作比较

    {

        pb = pb * 10 + db;

        b = b / 10;

    }

    printf ("%lld\n",pa + pb);

    return 0;

}

猜你喜欢

转载自blog.csdn.net/qq_40696484/article/details/80946888