1016 部分A+B (15 分)
正整数 A 的“(为 1 位整数)部分”定义为由 A 中所有 组成的新整数 。例如:给定 A=3862767,=6,则 A 的“6 部分” 是 66,因为 A 中有 2 个 6。现给定 A、、B、,请编写程序计算 。
输入格式:
输入在一行中依次给出 A、、B、,中间以空格分隔,其中 0<A,B<。
输出格式:
在一行中输出 的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
思路
这道题就是输入一个数字a,再输入一个数字Da,在a中找数字Da,比如a=123256 Da=2 那么之后定义的Pa就是22,因为a中有两个2
下面定义int其实也可以,只写#include<stdio.h>也是可以的,但是为了以防万一,我有时候就会定义的大一些,省得到时候报错
1.在一个数字里面找特定数字,可以使用循环将数字一个一个拆分,找出这些特定数字
2.将这些数字相乘相加,并储存在Pa中
3.处理B也是相同的方法
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
long long A,B,Da,Db;
int pa=0,pb=0;
scanf("%lld %lld %lld %lld",&A,&Da,&B,&Db);
while(A != 0)
{
if(A % 10 == Da) //% /是找Da相同的
/*
下面那个相加方式,可以看一下我写的1024 科学计数法
*/
pa = pa*10+Da;
//%取各位,/取除各位的其他数字
A /= 10;
}
while( B != 0)
{
if( B % 10 == Db)
pb = pb*10 + Db;
B /= 10;
}
printf("%d",pa+pb);
return 0;
}