题目选自洛谷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. cad表示计算机辅助,CAD计算机辅助设计之快捷键篇~( ̄▽ ̄)
  2. Android WiFi热点完全研究(自定义创建、跳转系统界面设置、读取配置、切换,Android6.0适配)...
  3. C++语言学习思维导图
  4. 解读全球海缆地图,带你看懂隐藏的秘密
  5. h5 兑换商品 页面模版_H5页面制作工具编辑功能对比:木疙瘩、微吾、云
  6. LeetCode Hot100 ---- 回溯算法专题
  7. zsh: command not found: nvm 解决方案
  8. python特征匹配 查找_特征匹配+单纯形查找对象
  9. C++:连接MySQL
  10. Python练习:合格率的计算
  11. Html数组下标访问帧,javaScript array(数组)使用字符串作为数组下标的方法
  12. Android 启动模拟器是出现 Failed to allocate memory 8 错误提示的原因及解决办法
  13. linux解压war包命令改配置文件脚本,自动解压war包,并替换胚子和文件,重启tomcat,实现自动化部署。...
  14. 关于Hsql无法插入的问题
  15. 计算机毕业设计springboot交通事故档案管理平台ryug8源码+系统+程序+lw文档+部署
  16. iOS socket编程(入门)
  17. 简单到出人意料的CNN图像分类策略
  18. 超详细,Python列表解析式到底该怎么用?
  19. 负数的二进制,原,反,补
  20. nasdaq qcom_高通(NASDAQ:QCOM)应该关注台湾半导体制造公司

热门文章

  1. 光华科技光刻胶_光刻胶概念走强,6天5板!21只光刻胶概念出炉!(名单)
  2. java的for循环取出数据只是拿到最后一个_如何保证缓存与数据库双写的一致性...
  3. 55种数据可视化开源工具_通过开源工具增强学生能力的15种方法
  4. input 底线_社区建设如何帮助组织的底线
  5. ldap radius_在LDAP上使用RADIUS的好处
  6. (37)Gulp 文件清除
  7. CSS 文本缩进text-indent属性
  8. es6 模块的语法严格模式
  9. oracle socct用户,oracle 19c 添加 scott用户与表
  10. java最大最小距离算法缺点_java算法(蓝桥杯)- 算法提高 题目1 最大最小值