B1016. 部分A+B

扫码查看

正整数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可以获得末位数字。

04-16 23:53
查看更多