计算辈分(并查集)

计算辈分:并查集算法实现
该博客介绍了一种使用并查集算法解决计算辈分问题的方法。通过建立家庭成员关系,程序可以确定两个人之间的辈分关系。在给定的示例中,程序能够正确输出两个人之间的辈分数值或在无直接关系时返回-1。



问题

 

计算辈分

 

我们国家有个独特的文化,就是把家族或亲戚之间的关系用辈分的单位来表示。这样的辈分会按照如下方式计算。

基本上把父母和子女之间定义为1辈,这样计算人之间的辈分。比如说,我和爸爸,爸爸和爷爷都是1辈,我和爷爷成为2辈,爸爸兄弟和爷爷是1辈,我和爸爸兄弟成为3辈。

当给出多个人的父母子女之间的关系时,请编写能计算提供的两个人辈分的程序。

输入

第一行给出所有人数 N。每个人的号码各个表示为1, 2, ..., N(1 ≤ N ≤ 100)

第二行给出需要计算辈分的两名不是同一个人的号码A, B(1 ≤ A, B ≤N)

第三行,给出父母子女之间的关系个数M

从第四行,通过M行空格划分给出表示父母子女之间关系的两个号码x, y。这时表示的是xy的父母。(1 ≤ x, y ≤ N)

输出

第一行输出A, B之间的辈分。有时候,因为两个人没有任何亲戚关系,所以无法计算辈分,这时请输出-1

 

案例输入

9

7 3

7

1 2

1 3

2 7

2 8

2 9

4 5

4 6

案例输出

3

 

 

#include<stdio.h>

 

intway[111][111], vis[111];

int n, m,x, y;

int ans =-1;

 

voiddfs(int node, int d = 0) {

   if (vis[node]) return;

   if (node == y) { ans = d; return; }

   vis [node] = 1;

   for (int i=1;i<=n;i++) {

       if (!way[node][i] || vis[i]) continue;

       dfs (i, d+1);

   }

}

 

int main(){

   scanf("%d%d%d%d",&n,&x,&y,&m);

   for (int i=1;i<=m;i++) {

       int a,b;

       scanf ("%d%d",&a,&b);

       way[a][b] = way[b][a] = 1;

   }

   dfs(x);

   printf ("%d",ans);

   return 0;

}

### Java 实现辈分计算器 为了构建一个能够处理复杂家庭关系的辈分计算器,可以采用面向对象编程的方法来表示不同的亲属关系。下面是一个简化版的例子,展示了如何通过类和方法定义来创建这样的程序。 #### 定义基础结构 首先,定义一个 `Person` 类作为所有人的基类: ```java class Person { private String name; public Person(String name) { this.name = name; } public String getName() { return name; } @Override public String toString() { return "Name=" + name; } } ``` 接着,为每种特定的家庭成员角色(如父亲、母亲等)创建具体的子类,并设置相应的属性和行为。 #### 创建具体的角色类 这里仅展示部分角色的实现方式;完整的解决方案应该覆盖所有的可能情况。 ##### Father.java ```java public class Father extends Person { private final Person spouse; public Father(String name, Person spouse) { super(name); this.spouse = spouse; } public Person getSpouse() { return spouse; } // 获取子女列表逻辑... } ``` ##### Mother.java ```java public class Mother extends Person { private final Person husband; public Mother(String name, Person husband) { super(name); this.husband = husband; } public Person getHusband() { return husband; } // 获取子女列表逻辑... } ``` 对于更复杂的家族树形图中的节点连接,则可以通过引入额外的数据结构来进行管理,比如使用哈希表存储每个人及其直系亲属之间的映射关系。 #### 构建查询功能 当有了上述的基础之后,就可以编写函数用于计算任意两个人之间的确切血缘或婚姻关系了。这通常涉及到遍历整个家谱网络直到到共同祖先为止的过程。 考虑到题目中提到的内容[^1],可以根据给定的关系模式建立对应的关联路径并据此推导出其他未直接提及的人物间联系。 例如,在已知某个人物A与其父母B,C的信息基础上,如果再得知D是C的儿子而E又是D的妻子的话,那么便能推出E相对于A来说就是儿媳的身份。 最后一步便是将这些概念转化为实际可运行的Java源码片段,不过由于篇幅所限无法在此处详尽列出全部细节。希望这个概览性的介绍有助于理解如何着手开发此类应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值