PAT (Basic Level) Practice1016 部分A+B

1016 部分A+B

一、题目

正整数 A 的" D A D_A DA(为 1 位整数)部分”定义为由 A 中所有 D A D_A DA 组成的新整数 P A P_A PA。例如:给定 A=3862767, D A D_A DA=6,则 A 的“6 部分” P A P_A PA 是 66,因为 A 中有 2 个 6。
现给定 A 、 D A 、 B 、 D B A、D_A、B、D_B ADABDB ,请编写程序计算 P A + P B P_A+P_B PA+PB
​​

二、输入输出

输入格式

输入在一行中依次给出 ,中间以空格分隔,其中 0 < A , B < 1 0 10 00<A,B<1010

输出格式

在一行中输出 P A + P B P_A+P_B PA+PB的值。

三、样例

输入样例1

3862767 6 13530293 3

输出样例1

399

输入样例2

3862767 1 13530293 8

输出样例2

0

四、题目分析

读入两组数据,设置和的初始值为零,对于每一组数据,遍历字符串,数字初始化为字符对应数字,每次找到对应字符,将数字加如sum中,再将数值乘十,作为下一次的加数。

五、代码

#include 
using namespace std;
int main()
{
     
    string s1, s2;
    char ch1, ch2;
    int num1, num2;
    int sum = 0;
    cin >> s1 >> ch1 >> s2 >> ch2;
    num1 = ch1 - '0';
    num2 = ch2 - '0';
    for (int i = 0; i < s1.length(); i++)
    {
     
        if (s1[i] == ch1)
        {
     
            sum += num1;
            num1 *= 10;
        }
    }
    for (int i = 0; i < s2.length(); i++)
    {
     
        if (s2[i] == ch2)
        {
     
            sum += num2;
            num2 *= 10;
        }
    }
    cout << sum;
    return 0;
}

你可能感兴趣的:(算法,#,PTA,c++,算法,PTA,oj系统)