Given a family tree, find out if two people are blood related
Given a family tree for a few generations for the entire population and two people write a routine that will find out if they are blood related. Siblings are blood related since they have the same parents. Cousins are blood related since one of their parents have the same parents etc. Design the data structure first and then write the routine.
https://www.careercup.com/question?id=4812957531766784
解法:G家,we can use DFS or BFS, DFS is generally a bit easier to implement.
If they have a common ancestor.
Data structure: Graph, becausd two parents. Store parents in an array or list rather than having a separate pointer for the father and mother.
DFS/BFS startig from 1 person is not ideal. BFS/Iterative Deepening for common ancestor from each person, as don't process unnecessary children.
Lots of ways to determine a common ancestor. pure recursion, recursively compute the ancestor set of both people and check intersection, iterative deepening to build up the sets.
Java:
For 2 persons to be blood related, perform a Breadth First Traversal with the person as root and the parents as child nodes and store in a ArrayList.
Then for both the persons search is there is a common parent in the ArrayList.
If common parent found then, the persons are related, else not related.
The data structure to store the generation tree will have nodes defined as
public class Person {
String name;
ArrayList<Person> children = null;
Person parent1;
Person parent2;
public Person(String personName, Person personParent1, Person personParent2) {
name = personName;
children = new ArrayList<Person>();
parent1 = personParent1;
parent2 = personParent2;
}
public Person getParent() { return parent; }
}
Java:
public class Person {
Person[] parents;
}
// naming for cousins is: n th cousin m times removed
// where n is the min generations to a common ancestor and m is the number of generations difference between the 2 cousins
// so this is going to be O((2^n+m)+2) which is still more efficient than dfs assuming the num generations in the population is > n+m
public boolean bloodRelated(Person p1, Person p2) {
// simple search would go down p1's children/grandchildren/etc and see if we find p2
// then vice versa
// then worry about cousin style relationships
// here we'd go up the parent tree on both until we found a common node (or ran out of data)
// we could take this last approach anyway and it would get us a parent-child match too
Set<Person> p1Ancestors = new HashSet<Person>();
Set<Person> p2Ancestors = new HashSet<Person>();
// so ideally here we're going to do BFS, but we're going to do 2 at once to try to minimise the depth we have to go
List<Person> p1Discovered = new LinkedList<Person>();
p1Discovered.add(p1);
List<Person> p2Discovered = new LinkedList<Person>();
p2Discovered.add(p2);
while (!p1Discovered.isEmpty() || !p2Discovered.isEmpty()) {
Person nextP1 = p1Discovered.remove(0);
if (nextP1 != null) {
if (p2Ancestors.contains(nextP1)) {
return true;
}
for (Person parent : nextP1.parents) {
p1Discovered.add(parent);
}
p1Ancestors.add(nextP1);
}
Person nextP2 = p2Discovered.remove(0);
if (nextP2 != null) {
if (p1Ancestors.contains(nextP2)) {
return true;
}
for (Person parent : nextP2.parents) {
p2Discovered.add(parent);
}
p2Ancestors.add(nextP2);
}
}
return false;
}
Given a family tree, find out if two people are blood related的更多相关文章
- openerp学习笔记 context 的应用
1.在Action中定义,context用于传递搜索条件和分组条件,在搜索视图中默认显示: 示例代码: <record model="ir.actions.act_window&quo ...
- 日常训练 dfs 之 拓扑排序
今天被拓扑排序给折磨了一天,主要就是我的一个代码有点小bug,真难找... 先来看看我今天写的题目吧! C. Fox And Names Fox Ciel is going to publish a ...
- python 自然语言处理(四)____词典资源
词典或者词典资源是一个词和/或短语及其相关信息的集合,例如:词性和词意定义等相关信息.词典资源附属于文本,而且通常在文本的基础上创建和丰富.下面列举几种nltk中的词典资源. 1. 词汇列表语料库 n ...
- [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法
二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ...
- SAP CRM 树视图(TREE VIEW)
树视图可以用于表示数据的层次. 例如:SAP CRM中的组织结构数据可以表示为树视图. 在SAP CRM Web UI的术语当中,没有像表视图(table view)或者表单视图(form view) ...
- 无限分级和tree结构数据增删改【提供Demo下载】
无限分级 很多时候我们不确定等级关系的层级,这个时候就需要用到无限分级了. 说到无限分级,又要扯到递归调用了.(据说频繁递归是很耗性能的),在此我们需要先设计好表机构,用来存储无限分级的数据.当然,以 ...
- 2000条你应知的WPF小姿势 基础篇<45-50 Visual Tree&Logic Tree 附带两个小工具>
在正文开始之前需要介绍一个人:Sean Sexton. 来自明尼苏达双城的软件工程师.最为出色的是他维护了两个博客:2,000Things You Should Know About C# 和 2,0 ...
- Leetcode 笔记 110 - Balanced Binary Tree
题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...
- Leetcode 笔记 100 - Same Tree
题目链接:Same Tree | LeetCode OJ Given two binary trees, write a function to check if they are equal or ...
随机推荐
- 马尔科夫链蒙特卡洛(MCMC) -- 学习笔记
https://blog.csdn.net/m0_38088359/article/details/83480258 https://blog.csdn.net/shenxiaolu1984/arti ...
- easyui-datagrid统计
<script> //打印指定的table function dayin() { var tableToPrint = document.getElementById("dg&q ...
- Intel 80386 CPU
一.80386 概述 80386处理器被广泛应用在1980年代中期到1990年代中期的IBM PC相容机中.这些PC机称为「80386电脑」或「386电脑」,有时也简称「80386」或「386」.80 ...
- Win32 Error
一.Win32错误 也就是Win32子系统产生的错误.当我们在自己的代码里调用Windows系统的API函数,系统执行API内部代码,当API内部代码出现错误,会将预先定义好的错误代码写到调用这个AP ...
- 2017.10.7 国庆清北 D7T1 计数
题目描述 给出m个数a[1],a[2],…,a[m] 求1~n中有多少数不是a[1],a[2],…,a[m]的倍数. 输入输出格式 输入格式: 输入文件名为count.in. 第一行,包含两个整数:n ...
- 单一职责原则(SRP)
内聚性:一个模块的组成元素之间的功能相关性.就一个类而言,应该仅有一个引起它变化的原因.当需求变化时,该变化会反映为类的职责的变化,如果一个类承担了多于一个的职责,那么引起它变化的原因就会有多个.如果 ...
- sem_init重复调用引发sem_wait线程无法被唤醒
问题 一段老代码,两个线程,一个线程调用sem_wait等待信号量,另外一个线程在某失败分支会调用sem_init清信号量,结果导致sem_wait线程无法被唤醒: 分析 Linux manpage ...
- 关于解决'\u'开头的字符串转中文的方法
如果字符串是”\u70ed\u95e8\u94ed\u6587\u63a8\u8350”这种形式的字符串: python3的解决办法:字符串.encode(‘utf-8’).decode(‘unico ...
- rockchip 硬解码相关
http://opensource.rock-chips.com/wiki_Mpp MPP You can get mpp source from git. git clone -b release ...
- nginx listen 端口 443 80 https 和 wss
端口号 443 和 80 端口的区别 一般指定 443 和 80 端口都是使用域名时所需要的 当我们使用域名请求时,一般是不添加端口号的 例如:http://www.baidu.com 在不添加端口号 ...