题目
正整数 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<1010 。
输出格式:
在一行中输出PA+PB的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
思路
- 在字符串
A
里面匹配整数DA
,每匹配到一个就加上10i - 本来是将
DA
和DB
也定义为字符串或字符的,这样匹配起来也比较容易,但是读入的时候出了点问题:
scanf("%s%s%s%s", A, DA, B, DB);
DA
的值读不进去,以后找到解决方法再补上。
代码
#include<stdio.h>
#include<math.h>
int getp(char * A, int DA)
{
int cou_a = 0, PA = 0;
for(int i = 0; A[i] ; i++)
if(A[i] - '0' == DA) PA += DA * pow(10, cou_a++);
return PA;
}
int main()
{
char A[12], B[12];
int DA = 0, DB = 0;
scanf("%s%d%s%d", A, &DA, B, &DB);
printf("%d\n", getp(A, DA) + getp(B, DB));
return 0;
}