猜字谜 华为OD真题 100

fb0277e7d6365991d31b9a0cbf79a7b3.png
dc38b12caea7011e3a7029c02654a846.png
4b1c9f6d9ef1969dbbb40ed3e9cab665.png
963f9ecef63876b4e3d8eb35de5b65d3.png

public class Main{
 
    public static void main(String[] args) {
 
        Scanner sc = new Scanner(System.in);
 
        String[] mimian = sc.nextLine().split(",");
        String[] midi = sc.nextLine().split(",");
 
        List<String> resList = new ArrayList<>();
        for(int i=0; i<mimian.length; i++){
            String mm = mimian[i];  //谜面
            boolean isFound = false;    //是否存在谜底
            for(int j=0; j<midi.length; j++){
                String md = midi[j];    //谜底
                if(bianxu(mm, md)){
                    resList.add(md);
                    isFound = true;
                }else if(quchong(mm, md)){
                    resList.add(md);
                    isFound = true;
                }
            }
            if(!isFound){
                resList.add("not found");
            }
        }
 
        String res = "";
        for(int i=0;i<resList.size();i++){
            res += resList.get(i) + ",";
        }
        System.out.println(res.substring(0,res.length()-1));
    }
 
    /**
     * 变序后谜面和谜底是否一致
     * @param miman
     * @param midi
     * @return
     */
    public static boolean bianxu(String miman, String midi){
 
        String[] mmStrs = miman.split("");
        Arrays.sort(mmStrs);
        String[] midiStrs = midi.split("");
        Arrays.sort(midiStrs);
 
        if(Arrays.equals(mmStrs, midiStrs)){
            return true;
        }
 
        return false;
    }
 
    /**
     * 去重后谜面与谜底是否一致
     * @param miman
     * @param midi
     * @return
     */
    public static boolean quchong(String miman, String midi){
 
        List<Character> mmList = new ArrayList<>();
        for(int i=0; i<miman.length(); i++){
            char c = miman.charAt(i);
            if(!mmList.contains(c)){
                mmList.add(c);
            }
        }
 
        List<Character> midiList = new ArrayList<>();
        for(int i=0; i<midi.length(); i++){
            char c = midi.charAt(i);
            if(!midiList.contains(c)){
                midiList.add(c);
            }
        }
 
        if(mmList.equals(midiList)){
            return true;
        }
        return false;
 
    }
 
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值