題目
正整數(shù) A 的“D?A(為 1 位整數(shù))部分”定義為由 A 中所有 DA組成的新整數(shù) PA屯远。例如:給定 A=3862767撕氧,DA=6针肥,則 A 的“6 部分”PA是 66谊囚,因?yàn)?A 中有 2 個 6婉陷。
現(xiàn)給定 A铣鹏、D?A鲜锚、B事哭、DB狈定,請編寫程序計(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
饺藤,每匹配到一個就加上10i - 本來是將
DA
和DB
也定義為字符串或字符的包斑,這樣匹配起來也比較容易流礁,但是讀入的時候出了點(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;
}