正整数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、B以字符串形式进行处理,用DA、DB对其进行匹配,注意字符与整型的转换,其他没什么可说的,10min内弄出来的题。。。
// 1016.cpp : 定义控制台应用程序的入口点。
//
//#include "stdafx.h"
#include<iostream>
#include<math.h>
using namespace std;
int main()
{
char A[11], B[11];
int DA, DB;
cin >> A >> DA >> B >> DB;
int i = 0, j = 0;
int PA = 0, PB = 0;
int daCount = 0;
int dbCount = 0;
while (A[i] != '\0')
{
int temp = A[i] - '0';
if (temp == DA)
{
PA += DA*pow(10, daCount);
daCount++;
}
i++;
}
while (B[j] != '\0')
{
int temp1 = B[j] - '0';
if (temp1 == DB)
{
PB += DB*pow(10, dbCount);
dbCount++;
}
j++;
}
cout << PA + PB << endl;
return 0;
}