2016去哪儿编程题:5-血型遗传检测

题目描述

血型遗传对照表如下:

父母血型子女会出现的血型子女不会出现的血型
O与OOA,B,AB
A与OA,OB,AB
A与AA,OB,AB
A与BA,B,AB,O——
A与ABA,B,ABO
B与OB,OA,AB
B与BB,OA,AB
B与ABA,B,ABO
AB与OA,BO,AB
AB与ABA,B,ABO
请实现一个程序,输入父母血型,判断孩子可能的血型。

 

给定两个字符串fathermother,代表父母的血型,请返回一个字符串数组,代表孩子的可能血型(按照字典序排列)。

测试样例:
”A”,”A”
返回:[”A”,“O”]
解题
字典给你了,直接HashMap就可以了,注意,父母的血型互换后结果是一样的。
import java.util.*;

public class ChkBloodType {
    /**
    *请实现一个程序,输入父母血型,判断孩子可能的血型。
    * 都给了,判断取出可能血型
    */
    public String[] chkBlood(String father, String mother) {
        // write code here 
        HashMap<String,String[]> map = new HashMap<String,String[]>();
        map.put("OO", new String[] { "O" });
        map.put("AO", new String[] { "A", "O" });
        map.put("OA", new String[] { "A", "O" });
        map.put("AA", new String[] { "A", "O" });
        map.put("AB", new String[] { "A", "AB", "B", "O" });
        map.put("BA", new String[] { "A", "AB", "B", "O" });
        map.put("AAB", new String[] { "A", "AB", "B" });
        map.put("ABA", new String[] { "A", "AB", "B" });
        map.put("BO", new String[] { "B", "O" });
        map.put("OB", new String[] { "B", "O" });
        map.put("BB", new String[] { "B", "O" });
        map.put("BAB", new String[] { "A", "AB", "B" });
        map.put("ABB", new String[] { "A", "AB", "B" });
        map.put("ABO", new String[] { "A", "B" });
        map.put("OAB", new String[] { "A", "B" });
        map.put("ABAB", new String[] { "A", "AB", "B" });
            
        return map.get(father + mother );
        
    }
}

 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值