题目描述
血型遗传对照表如下:
父母血型 | 子女会出现的血型 | 子女不会出现的血型 |
---|---|---|
O与O | O | A,B,AB |
A与O | A,O | B,AB |
A与A | A,O | B,AB |
A与B | A,B,AB,O | —— |
A与AB | A,B,AB | O |
B与O | B,O | A,AB |
B与B | B,O | A,AB |
B与AB | A,B,AB | O |
AB与O | A,B | O,AB |
AB与AB | A,B,AB | O |
给定两个字符串father和mother,代表父母的血型,请返回一个字符串数组,代表孩子的可能血型(按照字典序排列)。
测试样例:
”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 ); } }