正整数 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<109。
输出格式:
在一行中输出 PA+PB 的值。
#include <iostream>
using namespace std;
int main()
{
string a,b;
int da,db;
int pa,pb;
pa=0;pb=0;
int n=0,x=0;
int q=0,p=0;
cin>>a>>da>>b>>db;
for(int i=0;i<a.length();i++)
{
if(a[i]-'0'==da)
n++;
}
for(int i=0;i<b.length();i++)
{
if(b[i]-'0'==db)
x++;
}
while(q<n)
{
pa=pa*10+da;
q++;
}
while(p<x)
{
pb=pb*10+db;
p++;
}
cout<<(pa+pb);
cout<<endl;
return 0;
}
新手小白,感觉我的步骤还有些繁琐,求大神指教。
思路:一开始没有想到可以用string, 想了很久用int怎么算,后来看了一些例子有用string的才想到可以用string,主要是要求整数中有几个n,用int非常麻烦,用string可以用n-'0'=其本身的语句来算。