题目
题目描述
正整数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 < 10^10。
输出描述:
在一行中输出PA + PB的值。
输入例子:
3862767 6 13530293 3
输出例子:
399
解析
本题主要考察超大数的存储问题,本人使用string存储。
本人答案
#include <iostream>
#include <string>
using namespace std;
int main()
{
string A,B;
char DA,DB;
while(cin>>A>>DA>>B>>DB)
{
int tempA=0;
int tempB=0;
for(int i=0;i<A.size();i++)
{
if(A[i]==DA)
{
tempA=tempA*10+(DA-'0');
}
}
for(int i=0;i<B.size();i++)
{
if(B[i]==DB)
{
tempB=tempB*10+(DB-'0');
}
}
cout<<tempA+tempB;
}
}