【问题描述】
正整数A的“DA(为1位整数)部分”定义为由A中所有DA组成的新整数PA。例如:给定A = 3862767,DA = 6,则A的“6部分”PA是66,因为A中有2个6;给定A = 3862767,DA = 1,则A的“1部分”PA是0,因为A中有0个1。
现给定A、DA、B、DB,请编写程序计算PA + PB。
【输入形式】
输入在一行中依次给出A、DA、B、DB,中间以空格分隔,其中0 < A, B < 1010。
【输出形式】
在一行中输出PA + PB的值。
【样例输入】
3862767 6 13530293 3
【样例输出】
399
#include <iostream> #include <cmath> //因为用到函数pow所以要加这个头文件 using namespace std; int main() { string A,B; //因为A,B很大10的一百次,所以用string int D1,D2,t1=0,t2=0,s1=0,s2=0; cin>>A>>D1>>B>>D2; for(int i=0;i<A.length();i++) { if(A[i]-'0'==D1) //每个字符减去‘0’的ASCLL码来获得对应的数字,若没有我的输出的是空格 t1++; } for(int i=0;i<B.length();i++) { if(B[i]-'0'==D2) t2++; } for(int i=0;i<t1;i++) s1+=D1*pow(10,i); for(int i=0;i<t2;i++) s2+=D2*pow(10,i); cout<<s1+s2<<endl; return 0; }
1.不能把得出的数字存储在数组里,若存储在数组里到最后两个相加的时候就会卡住。
不喜勿喷,为自己复习使用!!!