1016 部分A+B (15 分)

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

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

输入格式:

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

输出格式:

在一行中输出 PA​​+PB​​ 的值。

输入样例 1:

3862767 6 13530293 3

输出样例 1:

399

输入样例 2:

3862767 1 13530293 8

输出样例 2:

0


注意判断先后顺序(别用Scanner):

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.math.BigInteger;
import java.nio.Buffer;
import java.util.*;    
public class Main{    

    public static void main(String[] args) throws IOException {
    
        //Scanner scanner = new Scanner(System.in);
        BufferedReader  bf=new BufferedReader(new InputStreamReader(System.in));
        
        String []str=bf.readLine().split(" ");
//        int a=Integer.parseInt(str[1]);
//        int b=Integer.parseInt(str[3]);
        if(str[0].contains(str[1])==false||str[2].contains(str[3])==false){
            System.out.println(0);
            return;
        }

        StringBuilder ra= new StringBuilder("");
        StringBuilder rb= new StringBuilder("");
        for(int i=0;i<str[0].length();i++){
            if(str[1].equals(str[0].charAt(i)+"")){
                ra.append(str[1]);
            }
        }
        for(int i=0;i<str[2].length();i++){
            if(str[3].equals(str[2].charAt(i)+"")){
                rb.append(str[3]);
        }
    }
//        if(ra.length()==0||rb.length()==0){
//            System.out.println(0);
//            return;
//        }


    
    BigInteger a1 = new BigInteger(ra.toString());
    BigInteger b1 = new BigInteger(rb.toString());
    System.out.println(a1.add(b1));

}
}
    

 ReaderBuffer为什么比Scanner快:https://blog.csdn.net/linxdcn/article/details/72886231

posted @ 2019-11-02 20:14  浅滩浅  阅读(145)  评论(0)    收藏  举报