题目描述
正整数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的值。
样例输入
3862767 6 13530293 3 3862767 1 13530293 8
样例输出
399 0
#include<cstdio>
#include<cstring>
int main()
{
char A[11],B[11];
int DA,DB;
long long PA=0,PB=0;
scanf("%s%d%s%d",&A,&DA,&B,&DB);
for(int i=0;i<strlen(A);i++)
{
if((A[i]-'0')==DA)
PA=PA*10+DA;
}
for(int i=0;i<strlen(B);i++)
{
if((B[i]-'0')==DB)
PB=PB*10+DB;
}
printf("%lld",PA+PB);
}
好像没必要...
看了下书上
直接
while(A!=0)
{
if(A%10=DA) ...
A=A/10...