题目选自洛谷P2814

由于是字符串保存名字,使用数字对应数组来合并查找有一点麻烦,所以使用map将对应关系存起来即可。

因为map带有映射关系,好像不需要再写初始化和合并操作,用两个字符串变量,一个保存当前父亲的名字,一个保存孩子的名字,根据第一个字符的判断分别对父亲和孩子进行操作。合并的过程,直接将父亲的名字给到map对应的孩子即可。

最后输出的时候,还行需要些find函数。

题目背景

现代的人对于本家族血统越来越感兴趣。

题目描述

给出充足的父子关系,请你编写程序找到某个人的最早的祖先。

输入格式

输入由多行组成,首先是一系列有关父子关系的描述,其中每一组父子关系中父亲只有一行,儿子可能有若干行,用 #name 的形式描写一组父子关系中的父亲的名字,用 +name 的形式描写一组父子关系中的儿子的名字;接下来用 ?name 的形式表示要求该人的最早的祖先;最后用单独的一个 $ 表示文件结束。

输出格式

按照输入文件的要求顺序,求出每一个要找祖先的人的祖先,格式为:本人的名字 + 一个空格 + 祖先的名字 + 回车。

输入输出样例

输入 1

#George
+Rodney
#Arthur
+Gareth
+Walter
#Gareth
+Edward
?Edward
?Walter
?Rodney
?Arthur
$

输出 1

Edward Arthur
Walter Arthur
Rodney George
Arthur Arthur

说明/提示

规定每个人的名字都有且只有 6 个字符,而且首字母大写,且没有任意两个人的名字相同。最多可能有 10^3 组父子关系,总人数最多可能达到 5×10^4 人,家谱中的记载不超过 30 代。

解题代码:

#include<stdio.h>
#include<iostream>
#include<string.h>
#include<map>
using namespace std;
char opt;
string s,s1;
map<string,string> ds;
string find(string x){if(x==ds[x]) return x;return ds[x] = find(ds[x]);
}
int main(){cin>>opt;while(opt != '$'){cin>>s;if(opt == '#'){s1=s;if(ds[s]=="") ds[s]=s;}else if(opt == '+'){ds[s] = s1;}else{cout<<s<<" "<<find(s)<<endl;}cin>>opt;}return 0;
}

并查集——家谱(洛谷 P2814)相关推荐

  1. 并查集——营救(洛谷 P1396)

    题目选自洛谷P1396 看到最大的最小很多人想到二分,但是可以有更好的解法. 我们不妨用并查集维护这个图,将边从小到大排序,每次取出边权最小的边,若该边的起点与终点未在一个集合内,就将其合并.当源点与 ...

  2. 并查集——团伙(洛谷 P1892)

    题目选自洛谷P1892 最基础的并查集是给出关系直接合并,这道题呢稍微多了一些条件,就是敌人的敌人也是自己的朋友,所以在合并的时候多了几步操作. 首先,要充分理解题目. "敌人的敌人就是朋友 ...

  3. 并查集——集合(洛谷 P1621)

    题目选自洛谷P1621 一道并查集类型的算法题,基本框架不变,就是合并的时候怎么合并,合并哪些数? 筛出素数之后找出在 'p~b' 范围内的素数 然后枚举a~b之间的数,合并他们 最后看看那些数的祖先 ...

  4. 并查集——亲戚(洛谷 P1551)

    题目选自洛谷P1551 并查集入门题目,简单有趣的例子了解并查集的使用 主要分为三个操作: 1)初始化 没有什么说的,就是用下标当做标号. 2)合并操作 如果两个关系的"老大"不一 ...

  5. 洛谷 P2814 家谱

    P2814 家谱 菜鸟生成记(45) 思路:并查集+map<string,string> 如果把这些字符串改为数字,这一题的就非常简单,就成了一个并查集模板题了:这一题难就难在map这个数 ...

  6. 0x41.数据结构进阶 - 并查集

    目录 一.路径压缩与按秩合并 1.AcWing 237. 程序自动分析(NOIP2015) 二.边带权并查集 1.AcWing 238. 银河英雄传说(边带权并查集模板) 2.AcWing 239. ...

  7. 洛谷题解——P2814 家谱

    题目相关 题目链接 洛谷,https://www.luogu.com.cn/problem/P2814. MYOJ,http://47.110.135.197/problem.php?id=5344. ...

  8. 并查集模板——并查集(洛谷 P3367)

    题目选自洛谷P3367 是并查集的最入门的题目,也是并查集的模板题~~ 如果你还不知道并查集是什么? 请看我的这篇文章 点击链接 题目描述 如题,现在有一个并查集,你需要完成合并和查询操作. 输入格式 ...

  9. 并查集——程序自动分析(洛谷 P1955)

    题目选自洛谷P1955 比较复杂一点的并查集题目,还用到了离散化的思想 首先明确一点:相等具有传递性,不相等不具有传递性(Eg:若x1等于x2,x2等于x3时,显然x1=x3.但当x1不等于x2,x2 ...

最新文章

  1. Neutron 物理部署方案 - 每天5分钟玩转 OpenStack(68)
  2. U盘从4G变为了75M 恢复U盘容量的方法
  3. 【Flutter】StatefulWidget 组件 ( FloatingActionButton 组件 | RefreshIndicator 组件 )
  4. Exchange安装
  5. Class类---反射学习笔记(一)
  6. 入驻支付宝开放平台并创建应用的基本流程
  7. 计算机网络的构成教学反思,《计算机网络知识》教学反思.doc
  8. python获取依赖包和安装依赖包
  9. Flask 和 Google App Engine 部署模型服务
  10. Nyoj 737: 石子合并(一)(区间DP+四边形优化)
  11. poj 2506 Tiling dp 递推
  12. Android6.0内核移植(1):分析编译日志
  13. 8月5日发布卡巴斯基授权许可key-卡巴斯基key
  14. 软考 系统分析师教程 免费拿走不谢
  15. 解决:win10有提示音,但是播视频没有声音
  16. Predicting mRNA Abundance Directly from Genomic Sequence Using Deep Convolutional Neural Networks
  17. Qt之鼠标滑过控件由箭头变成手型
  18. 阿昆同学的Java学习日记Day5
  19. 系统思考正反馈之马太效应
  20. utsc的计算机科学,天啊撸:中国留学生淘汰率竟比加拿大学生高出一倍

热门文章

  1. 秀秀自己电脑上的好东西
  2. Redis 常用配置参数
  3. SSM之Mybatis框架高级
  4. 用开源代码如何建立网站_建立开源社区时要考虑的6件事
  5. (17)Node.js第三方模块
  6. TypeScript 中类型 any,void,unknown,never之间的区别
  7. java登录功能多线程_java之多线程
  8. mysql dump 二进制_mysqldump+二进制日志备份恢复
  9. python数据序列题库_Python题库系列分享一(17道)
  10. 惯性导航算法_自动驾驶关键技术报告:惯性导航和背后的芯片大战