PAT 1016 部分A+B

https://pintia.cn/problem-sets/994805260223102976/problems/994805306310115328

 

正整数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
 
代码:
#include <bits/stdc++.h>

using namespace std;

const int maxn=1e5+10;
char a[maxn],b[maxn];

int main()
{
    int A,B;
    int cnt1=0,cnt2=0,sum1=0,sum2=0;
    scanf("%s%d%s%d",a,&A,b,&B);
    int len1=strlen(a);
    int len2=strlen(b);
    for(int i=0;i<len1;i++)
    {
        if(a[i]-'0'==A) cnt1++;
    }
    for(int i=0;i<len2;i++)
    {
        if(b[i]-'0'==B) cnt2++;
    }
    for(int i=1;i<=cnt1;i++)
    {
        sum1=sum1*10+A;
    }
    for(int i=1;i<=cnt2;i++)
    {
        sum2=sum2*10+B;
    }
    int sum=0;
    sum=sum1+sum2;
    //cout<<sum1<<endl<<sum2<<endl;
    printf("%d",sum);
    return 0;
}

  

posted @ 2018-07-07 21:49  丧心病狂工科女  阅读(185)  评论(0编辑  收藏  举报