1016 部分A+B (15分) PATJava代码实现

1016 部分A+B (15分)

正整数 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 D_{​A} DA​​ 、B、 D ​ B D_{​B} DB​​ ​​ ,请编写程序计算 P A P_{A} PA​​ + P B P_{B} PB​​ 。

输入格式:

输入在一行中依次给出 A、 D ​ A D_{​A} DA​​ 、B、 D ​ B D_{​B} DB​​ ,中间以空格分隔,其中 0 10 ​ 10 10​^{10} 1010​​ 。

输出格式:

在一行中输出 P​A​​ +P​B​​ 的值。

输入样例 1:

3862767 6 13530293 3

输出样例 1:

399

输入样例 2:

3862767 1 13530293 8

输出样例 2:

0

解题思路:

此题题目比较简单,A、B的范围为0到 10 ​ 10 10​^{10} 1010比较唬人。
我是用字符串来处理,比较简单。找到数字出现次数组装成数字然后求和即可。
通过观察测试用例可知若其中不存在给定的数,则为0。
此题约用时10分钟。

代码实现:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {
    public static void main(String[] args) throws IOException {
        //读取输入
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
        String[] s = bufferedReader.readLine().split(" ");
        bufferedReader.close();
        //默认赋初值0 若其中不存在给定数字也为0
        int numberA = 0;
        int numberB = 0;
        String a = s[0];
        String b = s[2];
        if(a.contains(s[1])){
            //记录出现次数
            int x = 0;
            char[] chars = a.toCharArray();
            for(char c : chars){
                if(c == s[1].charAt(0)){
                    numberA += Math.pow(10,x)*(c-'0');
                    x++;
                }
            }
        }
        if(b.contains(s[3])){
            //记录出现次数
            int y = 0;
            char[] chars = b.toCharArray();
            for(char c : chars){
                if(c == s[3].charAt(0)){
                    numberB += Math.pow(10,y)*(c-'0');
                    y++;
                }
            }
        }
        System.out.println(numberA+numberB);
    }
}

你可能感兴趣的:(PAT)