題目
正整數(shù) A 的“D?A(為 1 位整數(shù))部分”定義為由 A 中所有 DA組成的新整數(shù) PA。例如:給定 A=3862767,DA=6,則 A 的“6 部分”PA是 66,因?yàn)?A 中有 2 個(gè) 6。
現(xiàn)給定 A、D?A、B、DB,請(qǐng)編寫程序計(jì)算 P?A+P?B??。
輸入格式:
輸入在一行中依次給出 A、D?A、B、D?B ,中間以空格分隔,其中 0<A,B<10?10 。
輸出格式:
在一行中輸出P?A+PB的值。
輸入樣例 1:
3862767 6 13530293 3
輸出樣例 1:
399
輸入樣例 2:
3862767 1 13530293 8
輸出樣例 2:
0
?
思路
- 在字符串
A里面匹配整數(shù)DA,每匹配到一個(gè)就加上10i - 本來是將
DA和DB也定義為字符串或字符的,這樣匹配起來也比較容易,但是讀入的時(shí)候出了點(diǎn)問題:
scanf("%s%s%s%s", A, DA, B, DB);
DA的值讀不進(jìn)去,以后找到解決方法再補(bǔ)上。
?
代碼
#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;
}