• 题解

    • 无标号树的HASH:
    • 找到树的重心,以重心为根求出括号序列;
    • 由于树的重心最多只有两个,取字典序的最小括号序列HASH即可
    • 树的括号序列$s_{u}="(s_{v_{1}},s_{v_{2}},s_{v_{3}},...,s_{v_{n}})"$,同时字典序$s_{v_{1}} <= s_{v_{2}} <= ,... $
    • 有标号树的HASH:
    • 个人认为可以直接$prufer$序列$HASH$
    • 或者直接将儿子排个序$hash$,(总之乱搞)
    •  #include<bits/stdc++.h>
      #define ll long long
      #define mod 998244353
      using namespace std;
      const int N=;
      int n,m,hd[N],o,sz[N],mx[N],Mx,tot;
      struct Edge{int v,nt;}E[N<<];
      map<int,int>h;
      string now,s[N],tmp[N];
      void adde(int u,int v){
      E[o]=(Edge){v,hd[u]};hd[u]=o++;
      E[o]=(Edge){u,hd[v]};hd[v]=o++;
      }
      void get_rt(int u,int fa){
      sz[u]=;mx[u]=;
      for(int i=hd[u];~i;i=E[i].nt){
      int v=E[i].v;
      if(v==fa)continue;
      get_rt(v,u);
      sz[u]+=sz[v];
      mx[u]=max(mx[u],sz[v]);
      }
      mx[u]=max(m-sz[u],mx[u]);
      if(mx[u]<Mx)Mx=mx[u];
      }
      void dfs(int u,int fa){
      s[u]="(";
      for(int i=hd[u];~i;i=E[i].nt){
      int v=E[i].v;
      if(v==fa)continue;
      dfs(v,u);
      }
      tot=;
      for(int i=hd[u];~i;i=E[i].nt){
      int v=E[i].v;
      if(v==fa)continue;
      tmp[++tot]=s[v];
      }
      sort(tmp+,tmp+tot+);
      for(int i=;i<=tot;i++)s[u]=s[u]+tmp[i];
      s[u]+=")";
      }
      int main(){
      #ifndef ONLINE_JUDGE
      freopen("bzoj4337.in","r",stdin);
      freopen("bzoj4337.out","w",stdout);
      #endif
      scanf("%d",&n);
      for(int I=;I<=n;I++){
      o=;memset(hd,-,sizeof(hd));
      scanf("%d",&m);
      for(int i=,x;i<=m;i++){
      scanf("%d",&x);
      if(x)adde(x,i);
      }
      Mx=m;get_rt(,);
      now="";
      for(int i=;i<=m;i++)if(Mx==mx[i]){
      dfs(i,);
      if(now<s[i])now=s[i];
      }
      ll x=;
      for(int i=;i<(int)now.length();i++){
      x = ((x<<) + now[i])%mod;
      }
      //printf("%s\n",now.c_str());
      if(!h[x])h[x]=I;
      printf("%d\n",h[x]);
      }
      return ;
      }

      bzoj4337


【bzoj4337】【Bjoi2015】树的同构的更多相关文章

  1. bzoj4337: BJOI2015 树的同构 树哈希判同构

    题目链接 bzoj4337: BJOI2015 树的同构 题解 树哈希的一种方法 对于每各节点的哈希值为hash[x] = hash[sonk[x]] * p[k]; p为素数表 代码 #includ ...

  2. [BZOJ4337][BJOI2015]树的同构(树的最小表示法)

    4337: BJOI2015 树的同构 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1023  Solved: 436[Submit][Status ...

  3. BZOJ4337:[BJOI2015]树的同构(树hash)

    Description 树是一种很常见的数据结构. 我们把N个点,N-1条边的连通无向图称为树. 若将某个点作为根,从根开始遍历,则其它的点都有一个前驱,这个树就成为有根树. 对于两个树T1和T2,如 ...

  4. BZOJ4337: BJOI2015 树的同构(hash 树同构)

    题意 题目链接 Sol 树的同构问题,直接拿hash判一下,具体流程大概是这样的: 首先转化为有根树,预处理出第\(i\)棵树以\(j\)为根时的hash值. 那么两个树同构当且仅当把两棵树的hash ...

  5. bzoj4337: BJOI2015 树的同构

    hash大法好 #include <iostream> #include <cstdio> #include <cstring> #include <cmat ...

  6. 【BZOJ4337】BJOI2015 树的同构 括号序列

    [BZOJ4337]BJOI2015 树的同构 Description 树是一种很常见的数据结构. 我们把N个点,N-1条边的连通无向图称为树. 若将某个点作为根,从根开始遍历,则其它的点都有一个前驱 ...

  7. BZOJ 4337: BJOI2015 树的同构 树hash

    4337: BJOI2015 树的同构 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4337 Description 树是一种很常见的数 ...

  8. BZOJ4337:[BJOI2015]树的同构——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4337 树是一种很常见的数据结构. 我们把N个点,N-1条边的连通无向图称为树. 若将某个点作为根, ...

  9. 4337: BJOI2015 树的同构

    题解: 树的同构的判定 有根树从根开始进行树hash 先把儿子的f进行排序 $f[i]=\sum_{j=1}^{k} { f[j]*prime[j]} +num[i]$(我没有仔细想这样是不是树是唯一 ...

  10. [BJOI2015]树的同构

    嘟嘟嘟 判断树的同构的方法就是树上哈希. 如果树是一棵有根树,那么只要从根节点出发dfs,每一个节点的哈希值等于按传统方式算出来的子树的哈希值的结果.需要注意的是,算完子树的哈希值后要先排序再加起来, ...

随机推荐

  1. 深度学习-tensorflow学习笔记(1)-MNIST手写字体识别预备知识

    深度学习-tensorflow学习笔记(1)-MNIST手写字体识别预备知识 在tf第一个例子的时候需要很多预备知识. tf基本知识 香农熵 交叉熵代价函数cross-entropy 卷积神经网络 s ...

  2. truffle Dapp 搭建

    安装truffle $ npm install -g truffle 依赖环境 NodeJS 访问https://nodejs.org 官方网站下载安装 系统:Windows, Linux or Ma ...

  3. IOS statusBarStyle 设置

    在项目info.plist文件中有 View controller-based status bar appearance 属性. 当设置为NO时 通过 [UIApplication sharedAp ...

  4. which命令详解

    基础命令学习目录首页 原文链接:https://www.cnblogs.com/jkin/p/10289085.html Linux which命令用于查找文件. which指令会在环境变量$PATH ...

  5. 软件功能说明书final修订

    贪吃蛇(单词版)软件功能说明书final修订 1 开发背景 “贪吃蛇”这个游戏对于80,90后的人来说是童年的记忆,可以将其说为是一个时代的经典,实现了传统贪吃蛇的游戏功能:现在人们对英语的重视程度越 ...

  6. JAVA第一次实验 ——凯撒密码的实现

    JAVA实验一   编写程序实现凯撒密码 201352330 潘俊洋 一.实验说明 凯撒密码作为一种最为古老的对称加密体制,在古罗马的时候都已经很流行,他的基本思想是:通过把字母移动一定的位数来实现加 ...

  7. 20162328蔡文琛week08

    学号 20162328 <程序设计与数据结构>第X周学习总结 教材学习内容总结 错误和异常代表不常见的或不正确处理的对象. 抛出异常时输出的消息提供了方法调用栈的轨迹. 每个catch子句 ...

  8. sql索引的填充因子多少最好,填充因子有什么用

    和索引重建最相关的是填充因子.当创建一个新索引,或重建一个存在的索引时,你可以指定一个填充因子,它是在索引创建时索引里的数据页被填充的数量.填充因子设置为100意味着每个索引页100%填满,50%意味 ...

  9. week_2 四则运算

    coding地址: https://git.coding.net/lvgx/week_2.git 一. 需求分析 1.接收一个输入参数n,然后随机产生n道加减乘除(分别使用符号+-*÷来表示)练习题 ...

  10. nigix安装

    树莓派安装nginx,参考http://blog.csdn.net/zizi7/article/details/54347223 1. 下载PCRE 并安装. 主页地址: ftp://ftp.csx. ...