正整数A的“D(为1位整数)部分”定义为由A中所有D组成的新整数P。例如:给定A = 3862767,D = 6,则A的“6部分”P是66,因为A中有2个6。
现给定A、D、B、D,请编写程序计算P + P。
输入格式:
输入在一行中依次给出A、D、B、D,中间以空格分隔,其中0 < A, B < 10。
输出格式:
在一行中输出P + P的值。
输入样例1:
3862767 6 13530293 3
输出样例1:
399
输入样例2:
3862767 1 13530293 8
输出样例2:
0
#include<cstdio>
#include<iostream>
using namespace std;
int main(){
long long A, DA, B, DB;
scanf("%lld%lld%lld%lld", &A, &DA, &B, &DB);
long long PA = , PB = ;
while(A != ){
if(A % == DA) PA = PA * + DA;
A = A / ;
}
while(B != ){
if(B % == DB) PB = PB * + DB;
B = B / ;
}
printf("%lld\n", PA + PB);
return ;
}
注意:1、注意处理数的范围。int 与long 为4字节,约在2*10^9。long long为8字节,约在9*10^18 。
2、反复除以10,可以由低到高遍历每一位数字。 模10可以获得末位数字。