PAT乙级——1016(模拟计算)

版权声明:本文为博主原创文章,转载请注明原博客地址 https://blog.csdn.net/qunqunstyle99/article/details/83031881

题目:部分A+B (15 分)

正整数 A 的“DA(为 1 位整数)部分”定义为由 A 中所有 D​A组成的新整数 P​A​。例如:给定 A=3862767,D​A=6,则 A 的“6 部分”P​A是 66,因为 A 中有 2 个 6。

现给定 A、DA、B、DB​,请编写程序计算 P​A​​ +P​B

输入格式:
输入在一行中依次给出 A、D​A​、B、DB,中间以空格分隔,其中 0<A,B<1010​。

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

输入样例 1:
3862767 6 13530293 3
输出样例 1:
399

输入样例 2:
3862767 1 13530293 8
输出样例 2:
0

题目分析

将A和B按字符串读入,或一个一个的字符进行比较,或拆解成char型数组进行比较,计算相同的个数,累次增加PA*10+DA。最后得PA。PB同理。

编程实现

import java.util.Scanner;
public class Main {
    public static void main(String []args) {

        Scanner in = new Scanner(System.in);
        String A = in.next();
        int DA =in.nextInt();
        String B =in.next();
        int DB =in.nextInt();
        int PA=0,countA=0;
        int PB=0,countB=0;
        for(int i=0;i<A.length();i++){
            if((A.charAt(i)-48)==DA){
                countA++;
                if(countA==1)
                    PA+=DA;
                else
                    PA=PA*10+DA;

            }
        }
        for(int i=0;i<B.length();i++) {
            if ((B.charAt(i) - 48) == DB) {
                countB++;
                if (countB == 1)
                    PB += DB;
                else
                    PB = PB*10+DB;
            }
        }
        System.out.println(PA+PB);
    }
}

只能说实在是不够友好,每个用例都能通过,但是说不定哪个就会超时。多提交几次就可以AC了。
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qunqunstyle99/article/details/83031881