正整数 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
代码一:
#include <iostream>
#include <math.h>
using namespace std;
int main(){
string numset1;
string numset2;
int num1;
int num2;
cin >> numset1 >> num1>> numset2 >>num2;
int i,count1,count2;
count1 = 0;
count2 = 0;
for(i=0;numset1[i]!='\0';i++){
if((numset1[i]-'0') == num1){
count1++;
}
}
for(i=0;numset2[i]!='\0';i++){
if((numset2[i]-'0') == num2){
count2++;
}
}
int sum;
int sum1=0,sum2=0;
while(count1!=0){
sum1 += num1*pow(10,count1-1);
count1--;
}
while(count2!=0){
sum2 += num2*pow(10,count2-1);
count2--;
}
sum = sum1+sum2;
cout << sum;
}
代码二:
#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;
}
参考:http://https://blog.csdn.net/qq_22194315/article/details/52904966
总结:
- 统计相应数字出现的次数,再根据次数转化成位数
- 或者采用字符与整型的转换,这个简单点