洛谷 P5043 【模板】树同构([BJOI2015]树的同构)题解 树哈希 树的重心

【模板】树同构([BJOI2015]树的同构)

题目描述

树是一种很常见的数据结构。

我们把 N N N 个点, N − 1 N-1 N1 条边的连通无向图称为树。

若将某个点作为根,从根开始遍历,则其它的点都有一个前驱,这个树就成为有根树。

对于两个树 T 1 T_1 T1 T 2 T_2 T2,如果能够把树 T 1 T_1 T1 的所有点重新标号,使得树 T 1 T_1 T1 和树 T 2 T_2 T2 完全相同,那么这两个树是同构的。也就是说,它们具有相同的形态。

现在,给你 M M M 个无根树,请你把它们按同构关系分成若干个等价类。

输入格式

第一行,一个整数 M M M

接下来 M M M 行,每行包含若干个整数,表示一个树。第一个整数 N N N表示点数。接下来 N N N 个整数,依次表示编号为 1 1 1 N N N 的每个点的父亲结点的编号。根节点父亲结点编号为 0 0 0

输出格式

输出 M M M 行,每行一个整数,表示与每个树同构的树的最小编号。

样例 #1

样例输入 #1

4 
4 0 1 1 2 
4 2 0 2 3 
4 0 1 1 1 
4 0 1 2 3

样例输出 #1

1 
1 
3 
1

提示

编号为 1 , 2 , 4 1, 2, 4 1,2,4 的树是同构的。编号为 3 3 3 的树只与它自身同构。

对于 100 % 100\% 100% 的数据, 1 ≤ N , M ≤ 50 1\leq N,M\leq 50 1N,M50

原题

洛谷P5043——传送门

思路

对于有根树,如果两棵树的哈希值相同,那么二者是同构的。而对于无根树,可以寻找同位点即重心,令重心为根,将其转化为有根树。所以,对于此题,我们只需找到每棵树的所有重心,然后将其哈希值与前面的树的哈希值进行比较即可。

代码

#include <bits/stdc++.h>
using namespace std;
using i64 = long long;
typedef long long ll;const int MAX = 56;
vector<int> e[MAX];
vector<pair<int, int>> centre[MAX];
int siz[MAX], maxn[MAX];
int n;int dfs(int u, int fa)
{int res = 0;siz[u] = 0;for (int v : e[u]){if (v != fa){int num = dfs(v, u);siz[u] += num;res = max(res, num);}}maxn[u] = max(res, n - (siz[u] + 1));return siz[u] + 1;
}// 异或哈希
int Hash(int u, int fa)
{int res = 1;vector<int> num;for (int v : e[u]){if (v != fa)num.push_back(Hash(v, u));}sort(num.begin(), num.end());for (int x : num)res += x * 131 ^ 133331;return res;
}int solve(int idx)
{// 初始化for (int i = 0; i < MAX; i++){e[i].clear();maxn[i] = 0;}int fa;cin >> n;for (int i = 1; i <= n; i++){cin >> fa;if (fa != 0){e[i].push_back(fa);e[fa].push_back(i);}}// 找到树的所有重心dfs(1, 0);int tmp = INT_MAX;for (int i = 1; i <= n; i++){tmp = min(tmp, maxn[i]);}for (int i = 1; i <= n; i++){if (tmp == maxn[i])centre[idx].push_back({i, Hash(i, 0)}); // 存储第i个树对应的哈希值}for (pair<int, int> u : centre[idx]){// 遍历先前的树,寻找与其同构的树的最小编号for (int j = 1; j < idx; j++){for (pair<int, int> v : centre[j]){if (u.second == v.second) // 在有根树的条件下,哈希值相同的树是同构的(如果不发生哈希冲突)return j;}}}// 一定与自身同构return idx;
}int main()
{ios::sync_with_stdio(0);cin.tie(0);int m;cin >> m;for (int i = 1; i <= m; i++)cout << solve(i) << '\n';return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/25589.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

区块链共识机制技术一--POW(工作量证明)共识机制

1. 概述 POW&#xff08;Proof of Work&#xff0c;工作量证明&#xff09;是一种通过消耗计算能力来解决复杂数学问题&#xff0c;从而达到共识的机制。它是最早应用于区块链技术的共识算法&#xff0c;最著名的应用便是比特币网络。 2. 工作原理 在POW机制中&#xff0c;节点…

FinePrint软件下载及安装教程

【简介】 FinePrint是功能强大的Windows打印机驱动程序&#xff0c;使用旨在帮助用户轻松获得更好的打印效果和功能&#xff0c;并且能够节省你的时间、金钱、纸张和墨水。 FinePrint支持自动双面打印的虚拟打印机工具&#xff0c;使用这款软件可以帮助用户打印双面装订的书籍…

牛客网刷题 | BC120 争夺前五名

目前主要分为三个专栏&#xff0c;后续还会添加&#xff1a; 专栏如下&#xff1a; C语言刷题解析 C语言系列文章 我的成长经历 感谢阅读&#xff01; 初来乍到&#xff0c;如有错误请指出&#xff0c;感谢&#xff01; 描述 期中考试开始了&am…

Springboot整合SpringCache+redis简化缓存开发

使用步骤&#xff1a; 1.引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId> </dependency><dependency><groupId>org.springframework.boot</groupI…

Zookeeper高频面试题整理(入门到精通)

文章目录 1、什么是Zookeeper&#xff1f;2、ZooKeeper的基本数据结构是什么&#xff1f;3、Zookeeper的节点类型有哪些&#xff1f;4、Zookeeper的特点5、ZooKeeper如何保证数据一致性&#xff1f;6、什么是ZAB协议&#xff1f;7、Zookeeper的ACL机制是什么&#xff1f;8、Zoo…

平均召回(Average Recall,AR)概述

平均召回&#xff08;Average Recall&#xff0c;AR&#xff09;概述 在深度学习中&#xff0c;平均召回&#xff08;Average Recall, AR&#xff09;是一个衡量模型在不同阈值下的召回率的综合指标&#xff0c;特别常用于目标检测任务。召回率&#xff08;Recall&#xff09;…

js map遍历与promise一起使用出现的问题及解决方法

1.async/await 与Promise的关系 async/await是Promise的语法糖 let result await func() // > 等价于 func().then(result > {// code here })async function func () {return 1 } // > 等价与 function func () {return new Promise(resolve > resolve(1)) }2.…

学习java第九十七天

讲解一下核心容器&#xff08;spring context应用上下文) 模块 这是基本的Spring模块&#xff0c;提供Spring框架的基础功能&#xff0c;BeanFactory 是 任何以spring为基础的应用的核心。Spring 框架建立在此模块之上&#xff0c;它使Spring成为一个容器。 Bean工厂是工厂模式…

007 CentOS 7.9 apache-tomcat-9.0.89安装及配置

文章目录 一、准备工作二、安装Tomcat三、配置Tomcat四、启动Tomcat五、配置防火墙以允许远程访问六、测试远程访问 在CentOS 7.9上安装apache-tomcat-9.0.89.tar.gz并允许远程访问&#xff0c;可以按照以下步骤操作&#xff1a; 一、准备工作 确保已安装Java环境&#xff1a;…

MongoDB的基本操作介绍及使用

MongoDB是一种面向文档的NoSQL数据库&#xff0c;以其高性能、高可用性和易扩展性而受到广泛关注。以下是MongoDB的基本操作介绍及使用&#xff1a; 一、安装与配置 安装MongoDB相对简单&#xff0c;可以从MongoDB官网下载对应操作系统的安装包进行安装。在安装过程中&#x…

定个小目标之刷LeetCode热题(13)

今天来看看这道题&#xff0c;介绍两种解法 第一种动态规划&#xff0c;代码如下 class Solution {public int maxSubArray(int[] nums) {int pre 0, maxAns nums[0];for (int x : nums) {// 计算当前最大前缀和pre Math.max(pre x, x);// 更新最大前缀和maxAns Math.ma…

ansible.cfg forks参数

在Ansible的配置文件ansible.cfg中&#xff0c;forks参数是一个非常关键的设置&#xff0c;它控制了Ansible执行任务时的并发连接数&#xff0c;直接影响到Ansible执行 playbook 或 ad-hoc 命令时的速度和效率。 意义与作用 并发控制&#xff1a;当你使用Ansible来管理多台主…

【数据结构(邓俊辉)学习笔记】图04——双连通域分解

文章目录 0. 概述1 关节点与双连通域2 蛮力算法3 可行算法4 实现5 示例6 复杂度 0. 概述 学习下双连通域分解&#xff0c;这里略微有一点点难&#xff0c;这个算是DFS算法的非常非常经典的应用&#xff0c;解决的问题也非常非常有用。 1 关节点与双连通域 连通性很好理解&am…

rabbitmq单机安装及性能测试

RabbitMQ单机安装及性能测试 本文使用CentOS7.9安装RabbitMQ单机环境&#xff0c;并进行性能测试。 1. 安装RabbitMQ RabbitMQ依赖Erlang&#xff0c;版本配套关系参考官网&#xff1a;https://www.rabbitmq.com/docs/which-erlang。 本文安装RabbitMQ3.8.21,Erlang版本要求…

简单记录玩4399游戏flash插件问题

一、因谷歌浏览器默认禁止flash插件自动运行,所以玩家在使用谷歌浏览器,访问www.4399.com平台页面或者4399小游戏(flash资源)时,可能会出现加载异常的情况。今天教大家如何开启flash插件 二、下载falsh官方插件 地址:Flash Player官方下载中心-Flash中国官网 三、如果您…

ctfshow-web入门-命令执行(web30-web36)

目录 1、web30 2、web31 3、web32 4、web33 5、web34 6、web35 7、web36 命令执行&#xff0c;需要严格的过滤 1、web30 代码差不多&#xff0c;就是过滤的东西变多了&#xff1a; preg_match("/flag|system|php/i", $c) 这里不让用 system &#xff0c;我们…

掌握Excel字符串拼接

哈喽&#xff0c;大家好&#xff0c;我是木头左&#xff01; 在这个数字化时代&#xff0c;Excel已经成为了日常工作中不可或缺的工具。而字符串拼接作为Excel中的一项基本操作&#xff0c;对于提高工作效率、简化数据处理流程具有重要意义。本文将带你深入了解Excel字符串拼接…

离散数学答疑 4

知识点&#xff1a;什么是可结合&#xff1f; 举例A选项&#xff1a; 知识点&#xff1a;可交换性? 知识点&#xff1a;什么是阿贝尔群&#xff1f; 可交换->运算表中的元素关于主对角线对称 二阶子群的表达式 二阶子群作为一个群的子群&#xff0c;其本质是一个包含单位元…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 伐木工(200分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 📎在线评测链接 伐木工(200分) 🌍 评测功能需要订阅专栏后私信联系清隆解…

【机器学习】Qwen2大模型原理、训练及推理部署实战

目录​​​​​​​ 一、引言 二、模型简介 2.1 Qwen2 模型概述 2.2 Qwen2 模型架构 三、训练与推理 3.1 Qwen2 模型训练 3.2 Qwen2 模型推理 四、总结 一、引言 刚刚写完【机器学习】Qwen1.5-14B-Chat大模型训练与推理实战 &#xff0c;阿里Qwen就推出了Qwen2&#x…