本文主要是介绍一千题,No.0030(部分A+B),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
正整数 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 的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
解题思路:
水题++
计算数量构成数字相加输出即可
c++代码如下:
#include <bits/stdc++.h>using namespace std;int func(int a,int n)
{int sum = 0;int i = 1;while(n--){sum += i*a;i = i*10;}return sum;
}int main()
{string s1,s2;string a1,a2;cin >> s1 >> a1 >> s2 >> a2;//计数int x = 0;int y = 0;for(int i = 0;i<s1.size();++i){if(s1[i] == a1[0]){++x;}}for(int i = 0;i<s2.size();++i){if(s2[i] == a2[0]){++y;}}//输出cout << func(stoi(a1),x) + func(stoi(a2),y);
}
这篇关于一千题,No.0030(部分A+B)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!