PAT B-1016 部分A+B

正整数 A 的“D​A​​(为 1 位整数)部分”定义为由 A 中所有 D​A​​ 组成的新整数 P​A​​。例如:给定 8,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。

输出格式:

在一行中输出 P​A​​+P​B​​ 的值。

输入样例 1:

3862767 6 13530293 3

输出样例 1:

399

输入样例 2:

3862767 1 13530293 8

输出样例 2:

0
实现:
# include<cstdio> int main(){ long long number1,number2,d1,d2;//十的十次方大于int ,用long long 存储 scanf("%lld%lld%lld%lld", &number1, &d1, &number2, &d2); long long pa=0,pb=0; while(number1!=0){//枚举每一位数,若等于d,则累成赋值给pa if(number1%10==d1) pa=pa*10+d1; number1=number1/10; } while(number2!=0){ if(number2%10==d2) pb=pb*10+d2; number2=number2/10; } printf("%lld\n", pa+pb); return 0;
}
上一篇:leetcode 1016. 子串能表示从 1 到 N 数字的二进制串(Binary String With Substrings Representing 1 To N)


下一篇:PAT乙级1016