并查集——家谱(洛谷 P2814)
题目选自洛谷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)相关推荐
- 并查集——营救(洛谷 P1396)
题目选自洛谷P1396 看到最大的最小很多人想到二分,但是可以有更好的解法. 我们不妨用并查集维护这个图,将边从小到大排序,每次取出边权最小的边,若该边的起点与终点未在一个集合内,就将其合并.当源点与 ...
- 并查集——团伙(洛谷 P1892)
题目选自洛谷P1892 最基础的并查集是给出关系直接合并,这道题呢稍微多了一些条件,就是敌人的敌人也是自己的朋友,所以在合并的时候多了几步操作. 首先,要充分理解题目. "敌人的敌人就是朋友 ...
- 并查集——集合(洛谷 P1621)
题目选自洛谷P1621 一道并查集类型的算法题,基本框架不变,就是合并的时候怎么合并,合并哪些数? 筛出素数之后找出在 'p~b' 范围内的素数 然后枚举a~b之间的数,合并他们 最后看看那些数的祖先 ...
- 并查集——亲戚(洛谷 P1551)
题目选自洛谷P1551 并查集入门题目,简单有趣的例子了解并查集的使用 主要分为三个操作: 1)初始化 没有什么说的,就是用下标当做标号. 2)合并操作 如果两个关系的"老大"不一 ...
- 洛谷 P2814 家谱
P2814 家谱 菜鸟生成记(45) 思路:并查集+map<string,string> 如果把这些字符串改为数字,这一题的就非常简单,就成了一个并查集模板题了:这一题难就难在map这个数 ...
- 0x41.数据结构进阶 - 并查集
目录 一.路径压缩与按秩合并 1.AcWing 237. 程序自动分析(NOIP2015) 二.边带权并查集 1.AcWing 238. 银河英雄传说(边带权并查集模板) 2.AcWing 239. ...
- 洛谷题解——P2814 家谱
题目相关 题目链接 洛谷,https://www.luogu.com.cn/problem/P2814. MYOJ,http://47.110.135.197/problem.php?id=5344. ...
- 并查集模板——并查集(洛谷 P3367)
题目选自洛谷P3367 是并查集的最入门的题目,也是并查集的模板题~~ 如果你还不知道并查集是什么? 请看我的这篇文章 点击链接 题目描述 如题,现在有一个并查集,你需要完成合并和查询操作. 输入格式 ...
- 并查集——程序自动分析(洛谷 P1955)
题目选自洛谷P1955 比较复杂一点的并查集题目,还用到了离散化的思想 首先明确一点:相等具有传递性,不相等不具有传递性(Eg:若x1等于x2,x2等于x3时,显然x1=x3.但当x1不等于x2,x2 ...
最新文章
- Neutron 物理部署方案 - 每天5分钟玩转 OpenStack(68)
- U盘从4G变为了75M 恢复U盘容量的方法
- 【Flutter】StatefulWidget 组件 ( FloatingActionButton 组件 | RefreshIndicator 组件 )
- Exchange安装
- Class类---反射学习笔记(一)
- 入驻支付宝开放平台并创建应用的基本流程
- 计算机网络的构成教学反思,《计算机网络知识》教学反思.doc
- python获取依赖包和安装依赖包
- Flask 和 Google App Engine 部署模型服务
- Nyoj 737: 石子合并(一)(区间DP+四边形优化)
- poj 2506 Tiling dp 递推
- Android6.0内核移植(1):分析编译日志
- 8月5日发布卡巴斯基授权许可key-卡巴斯基key
- 软考 系统分析师教程 免费拿走不谢
- 解决:win10有提示音,但是播视频没有声音
- Predicting mRNA Abundance Directly from Genomic Sequence Using Deep Convolutional Neural Networks
- Qt之鼠标滑过控件由箭头变成手型
- 阿昆同学的Java学习日记Day5
- 系统思考正反馈之马太效应
- utsc的计算机科学,天啊撸:中国留学生淘汰率竟比加拿大学生高出一倍