正整数 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<109。
输出格式:
在一行中输出 PA+PB 的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
代码长度限制
16 KB
时间限制
150 ms
内存限制
64 MB
容易看出,本题还挺简单,就直接上代码,不做过多说明。
#include<stdio.h>
#include<math.h>
int P(int num,int key){
int cnt=0,number=0;
while(num){
if((num%10)==key){
number+=pow(10,cnt)*key;//这里也可以不使用pow函数,但是要注意cnt代表位
cnt++;
}
num/=10;
}
return number;
}
int main(){
int A,B,DA,DB,PA,PB;
scanf("%d%d%d%d",&A,&DA,&B,&DB);
PA=P(A,DA);
PB=P(B,DB);
printf("%d",PA+PB);
return 0;
}
运行结果

这篇文章介绍了一个编程问题,要求根据给定的正整数 A 和 DA,以及 B 和 DB,计算它们对应 DA 部分 PA 和 PB 的和。通过简单的算法实现,展示了如何快速求解这一涉及数字位操作的问题。
4万+

被折叠的 条评论
为什么被折叠?



