正整数 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<10^10 。
输出格式:
在一行中输出 PA +PB 的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
题目分析
这个题只要想到用字符串,先计算出DA,DB的个数就容易做了。
#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{
char A[100],B[100],Da,Db;
int i,j,n1=0,n2=0;
cin>>A>>Da>>B>>Db;
for(i=0;A[i]!='\0';i++)
{
if(A[i]==Da)
n1++;
}
int m=0,n=0;
for(j=0;j<n1;j++)
m+=pow(10,j)*(Da-'0');
for(i=0;B[i]!='\0';i++)
{
if(B[i]==Db)
n2++;
}
for(j=0;j<n2;j++)
n+=pow(10,j)*(Db-'0');
cout<<m+n<<endl;
}
这次我是一遍过呀,开心!