问题描述(来源于以前上过的一门课)
一些家史复杂的家族会记录家谱。家谱是同一个姓的族人的一个集合,从最原始的祖先开始记录,之后每次新诞生的、与祖先有血缘关系的同姓族人都会被记录在案。
  一个家庭,我们定义为一个族人和其直属同姓子女这两代人的集合。比如男性族人A,生了一个女儿B,接着生了一个儿子C,然后生了一个女儿D。那么A-BCD可以被称为一个以A为祖先的家庭。两个家庭称为相似,当且仅当两个家庭有相同的结构。比如男性族人E,生了一个女儿F,接着生了一个儿子G,然后生了一个女儿H,那么家庭E-FGH可以和家庭A-BCD称为相似。但比如男性族人I,生了两个女儿J、K,再生了一个儿子L,那么家庭I-JKL和家庭A-BCD就不能称为相似。或一个男性族人M,生了一个女儿N,接着生了一个儿子O,那家庭M-NO也不能和家庭A-BCD称为相似。或一个女性族人P,生了一个女儿Q,接着生了一个儿子R,然后生了一个女儿S,那家庭P-QRS也不能和家庭A-BCD称为相似。如果一个族人没有后代,那么他/她自己一个人也形成一个家庭。
  一个子族,我们定义为一个族人和其所有直属同姓后代的集合。比如B生了一个儿子T,C生了两个女儿U、V,T生了一个女儿W,那么A-B=T~W-C=UV-D就可以称为以A为祖先的子族。同样子族判断相似的标准和家庭相同,当且仅当两个子族拥有相同的结构才能被认为相似。
  现在告知一个家族的家谱,请你回答一些关于相似性的问题。
输入格式
第一行两个正整数N、Q,表示家谱的长度和询问的个数。
  接下来N行描述家谱,每行的格式为两个只包含小写字母的字符串parent、child和一个字符’M’或’F’,表示名为parent的族人生了一个孩子叫做child,child的性别为’M’(代表男)或’F’(代表女)。家谱的描述以日期顺序,即同一家庭中,先描述的是哥哥/姐姐,后描述的是弟弟/妹妹。
  接下来是Q行询问,每行有可能是:
  1.一个字符’F’和一个字符串parent,表示询问有多少家庭和以parent为祖先的家庭相似(不包括parent自身)。
  2.一个字符’S’和一个字符串parent,表示询问有多少子族和以parent为祖先的子族相似(不包含parent自身)。
  最原始的祖先名字为字符串’root’,性别为男性。
  族人的名字两两不同。
  数据保证合法性,且数据默认没有族人之间结婚的情况。
输出格式
对于每个询问输出一行一个整数表示答案。

#include <iostream>
#include <string>
#include <queue>
#include <map>
using namespace std;
const int q1 = 999999937;
const int q2 = 999992221;
int a = 2, b = 3;void Generate(map<string, int> &t, string parent, string child, char gender) { //生成第一个map,人名->家庭int g;if (gender == 'F') g = 2;else g = 1;        t[child] = g;t[parent] = (a*t[parent] + b*g) % q1;
}void Family(map<string, int> t, map<int, int> &r) { //生成第二个map,家庭->拥有与该家庭一样的结构的人数map<string, int>::iterator iter;iter = t.begin();while (iter != t.end()) {r[iter->second]++;iter++;}
}
int main(int argc, const char * argv[]) {int N, Q;string parent, child, order, name;char gender;map<string, int> tree;map<int, int> result;cin >> N >> Q;tree["root"] = 1;for (int i = 0; i < N; i++) {cin >> parent >> child >> gender;Generate(tree, parent, child, gender);}Family(tree, result);for (int i = 0; i < Q; i++) {cin >> order >> name;if (order == "F") {cout << result[tree[name]] - 1 << endl;}if (order == "Q") {//待解决}}
}

目前只解决了F类的询问,往后尝试解决Q类的询问。

利用c++STL中的map实现基本哈希族谱相关推荐

  1. c++的STL中的map(哈希表)与unordered_map

    map: unordered_map: map: map内部实现了一个红黑树,该结构具有自动排序的功能,因此map内部的所有元素都是有序的 unordered_map:unordered_map内部实 ...

  2. 红黑树实现——STL中的map

    From: http://blog.csdn.net/zhongjiekangping/article/details/6934571 红黑树实现--STL中的map [ 2009-07-24 13: ...

  3. STL中的map、unordered_map、hash_map

    转自https://blog.csdn.net/liumou111/article/details/49252645 在之前使用STL时,经常混淆的几个数据结构,特别是做Leetcode的题目时,对于 ...

  4. 关于STL中的map和hash_map

    在网上看到有关STL中hash_map的文章,以及一些其他关于STL map和hash_map的资料,总结笔记如下:     1.STL的map底层是用红黑树实现的,查找时间复杂度是log(n):   ...

  5. 关于STL中的map用法

      STL中map用法详解         std map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力, ...

  6. STL中的map简单详解

    std map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数 ...

  7. 利用EXCEL表格中Power Map实现大数据可视化操作

    一.打开数据表格 首先打开我们事先准备好的2017年世界各国和地区GDP排名数据表格,里面有排名栏.国家地区栏.2016GDP栏.2017GDP栏.GDP增速栏.人均GDP栏以及人口栏,样式如下: 二 ...

  8. STL中的map集合扩展字段比较方便

    扩展字段map<string, string>真是个好东西, 在定各种协议时很常用,便于扩展 #include <iostream> #include <map> ...

  9. 【C++ 包装器类 map】C++ 标准库(std)中的map结构 哈希表(unordered_map)和黑红树(map)教程

    目录标题 1. 哈希表(unordered_map)和黑红树(map)简介以及初始化 1.1 哈希表的基本介绍 1.1.1 哈希表初始化接口示例 1.1.2 哈希表的键值的注意事项 1.1.3 自定义 ...

最新文章

  1. rabbitmy实战
  2. vsftpd + mysql + virtual users
  3. dotnet安装包时找不到依赖关系_孩子总找妈妈,小心单方父母过渡依赖症,4个方法让父母更平等...
  4. C#中三种截屏方式总结
  5. JDK12的新特性:CompactNumberFormat
  6. 如何处理几十万条并发数据_Swoole 如何处理高并发以及异步 I/O 的实现
  7. 电脑:电脑弹窗广告三个解决方法,欢迎收藏!
  8. 用eclipse创建动态web项目手动生成web.xml方法
  9. ACM001 Quicksum
  10. 有向图算法 PHP,科学网—一种可用于脑神经网络分析的有向图分解算法 第六稿 - 谢勤的博文...
  11. alt和title的区别与用法
  12. 上一页下一页html样式,软件 | hexo博客主题yilia上一页下一页显示的问题
  13. ps形状工具组的使用
  14. 在计算机检索中 有哪些方法能缩小,使用“或OR”运算将同义词连接起来可以缩小检索。()...
  15. 重装系统后dell戴尔笔记本电脑插入耳机没有声音
  16. BLC 以及 线性化
  17. python return break_Python基础:return和break的不同
  18. 案例:自动登录12306
  19. sharepoint能做什么,门户开发出来是什么效果,这里转一个个人产品的案例
  20. Nginx篇01-基本安装配置和静态页面设置

热门文章

  1. 成都软件从业人员达20万人
  2. Go语言Iris开发框架
  3. 夜神模拟器访问本地服务器
  4. java 生成 cookie_Java实现 Cookie的生成与读取
  5. java项目全局替换,Java开发:使用IntelliJ IDEA全局内容搜索和替换功能
  6. 柬埔寨暂缓征收跨境电子商务增值税;亚马逊新加坡站将推出“Easy Ship”服务;出海品牌EUNA完成天使轮融资...|洞悉跨境
  7. GBase 8c数据类型
  8. B站黑马测试第二篇P206视频数据库SQL语句‘关联查询_数据准备‘代码
  9. 雪域高原,飘起“联想 智慧中国”红
  10. 南京邮电大学通达学院c语言实验报告,南京邮电大学通达学院c语言程序报告.docx...