• 题解:

    • 如果树上某个路径串的端点不是叶子,那么一定是另一个串的子串;
    • 这样只对叶子$dfs$把$20*20$个串插入广义$SAM$就是统计本质不同的串的个数的模板了;
    • 我不太会分析广义$SAM$的空间,但是我知道似乎完全图是有$n-1$条欧拉回路的,所以长度不会超过$2n*(20-1)$,需要卡一卡;
    • 可能后面会补广义的坑吧。。。。
    •  #include<bits/stdc++.h>
      #define rg register
      #define il inline
      #define ll long long
      using namespace std;
      const int N=,M=;
      int n,m,sz,mx[N*M],pa[N*M],s[N],len,col[N],ch[N*M][],d[N],cnt,a[N],w[N],st[N*M],o,hd[N];
      ll val[N*M];
      struct Edge{int v,nt;}E[N<<];
      il char gc(){
      static char*p1,*p2,S[];
      if(p1==p2)p2=(p1=S)+fread(S,,,stdin);
      return(p1==p2)?EOF:*p1++;
      }
      il int rd(){
      int x=;char c=gc();
      while(c<''||c>'')c=gc();
      while(c>=''&&c<='')x=(x<<)+(x<<)+c-'',c=gc();
      return x;
      }
      il void adde(int u,int v){
      E[o]=(Edge){v,hd[u]};hd[u]=o++;d[u]++;
      E[o]=(Edge){u,hd[v]};hd[v]=o++;d[v]++;
      }
      il void ins(){
      /*
      for(int i=1;i<=len;i++)printf("%d ",s[i]);
      puts("");
      */
      int lst=,np,nq,p,q,x;
      for(rg int i=;i<=len;i++){
      x=s[i];
      p=lst; mx[lst=np=++sz]=mx[p]+;
      while(p&&!ch[p][x])ch[p][x]=np,p=pa[p];
      if(!p){pa[np]=;continue;}
      q=ch[p][x];
      if(mx[q]==mx[p]+)pa[np]=q;
      else {
      mx[nq=++sz]=mx[p]+;
      memcpy(ch[nq],ch[q],sizeof(ch[q]));
      pa[nq]=pa[q];pa[q]=pa[np]=nq;
      while(p&&ch[p][x]==q)ch[p][x]=nq,p=pa[p];
      }
      }
      }
      il void dfs(int u,int fa){
      for(rg int i=hd[u];i;i=E[i].nt){
      int v=E[i].v;
      if(v==fa)continue;
      s[++len]=col[v];
      dfs(v,u);
      }
      if(d[u]==&&fa)ins();
      len--;
      }
      int main(){
      #ifndef ONLINE_JUDGE
      freopen("bzoj3926.in","r",stdin);
      freopen("bzoj3926.out","w",stdout);
      #endif
      n=rd();m=rd();
      for(rg int i=;i<=n;i++)col[i]=rd();
      for(rg int i=o=;i<n;i++)adde(rd(),rd());
      sz=;
      for(rg int i=;i<=n;i++)if(d[i]==)a[++cnt]=i;
      for(int i=;i<=cnt;i++){
      s[len=]=col[a[i]];
      dfs(a[i],);
      }
      for(rg int i=;i<=sz;i++)w[mx[i]]++;
      for(rg int i=;i<=n;i++)w[i]+=w[i-];
      for(rg int i=sz;i;i--)st[w[mx[i]]--]=i;
      for(rg int i=sz,u;i;i--){
      val[u=st[i]]=;
      for(rg int j=;j<m;j++){
      val[u]+=val[ch[u][j]];
      }
      }
      --val[];
      printf("%lld\n",val[]);
      return ;
      }

      bzoj3926

【bzoj3926】【Zjoi2015】诸神眷顾的幻想乡的更多相关文章

  1. bzoj3926: [Zjoi2015]诸神眷顾的幻想乡 对[广义后缀自动机]的一些理解

    先说一下对后缀自动机的理解,主要是对构造过程的理解. 构造中,我们已经得到了前L个字符的后缀自动机,现在我们要得到L+1个字符的后缀自动机,什么需要改变呢? 首先,子串$[0,L+1)$对应的状态不存 ...

  2. BZOJ3926 [Zjoi2015]诸神眷顾的幻想乡 字符串 SAM

    原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ3926.html 题目传送门 - BZOJ3926 题意 给定一个有 $n$ 个节点,最多只有 $20$ ...

  3. BZOJ3926:[ZJOI2015]诸神眷顾的幻想乡(广义SAM)

    Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看. ...

  4. [BZOJ3926][ZJOI2015]诸神眷顾的幻想乡(后缀自动机)

    日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看.幽香当然也非常高兴啦.  这时幽香发现了一件非常有趣的事情,太阳花田有n块空地.在过去 ...

  5. BZOJ3926 Zjoi2015 诸神眷顾的幻想乡【广义后缀自动机】

    Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看. ...

  6. BZOJ3926 [Zjoi2015]诸神眷顾的幻想乡 【广义后缀自动机】

    题目 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看.幽香当然也非常高兴 ...

  7. BZOJ3926: [Zjoi2015]诸神眷顾的幻想乡(广义后缀自动机)

    Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看. ...

  8. BZOJ3926 ZJOI2015诸神眷顾的幻想乡(广义后缀自动机)

    对多串建立SAM的一种方法是建trie再对trie建SAM.构造方式分为在线(也即不建trie而是依次插入每个串,或在trie上dfs)和离线(也即建好trie再bfs).其中离线构造与单串的构造方式 ...

  9. bzoj3926: [Zjoi2015]诸神眷顾的幻想乡

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  10. BZOJ3926 ZJOI2015 诸神眷顾的幻想乡 Trie、广义SAM

    传送门 树上的任意一条路径一定会在以某一个叶子节点为根的树上成为一条直上直下的链,而总共只有\(20\)个叶子节点. 于是每一次选所有叶子节点中的一个作为根,形成一个\(Trie\),把\(20\)个 ...

随机推荐

  1. RAID中条带的概念

    raid把数据分成条带,一个条带横跨所有数据磁盘,每个磁盘上存储条带的一部分,称为sagment,也称为条带深度.一个条带包含的扇区或块的个数,称为条带长度. raid向操作系统提供的是卷,是连续的扇 ...

  2. maven实战读书笔记(二)

    一个Spring加载属性的工具类,指定目标位置之后可以用${}的方式加载配置文件 测试maven工程发送email的例子:运行成功的例子—github 常用的命令: mvn clean compile ...

  3. Scrum Meeting 10 -2014.11.16

    开始进入大项目的整合阶段,平时和其他两个小组交流较少,整合难度还是存在的. 在具体整合前,让开发人员添加了些必要的注释,优化代码结构,方便阅读. Member Today’s task Next ta ...

  4. Task 6.2冲刺会议四 /2015-5-17

    今天主要是学习并熟悉了C#的开发流程,把他的文件的大体结构和每个组件之间的联系弄清楚之后.开始写服务器部分的内容.学习过程中,感觉网上的资料有些太鱼龙混杂了,不知道该怎么取舍.明天准备完善服务器的功能 ...

  5. mysql 性能分析及explain用法

    转载自http://blog.sina.com.cn/s/blog_4586764e0100o9s1.html 使用explain语句去查看分析结果 如   explain select * from ...

  6. Source Insight中的多行注释

    转自:http://www.cnblogs.com/dongzhiquan/archive/2013/03/04/2943448.html 我们经常要对一整段代码进行注释,很多代码编辑器都提供了这样的 ...

  7. Freemarker中Configuration的setClassForTemplateLoading方法参数问题

    今天使用freemarker中Configuration的setClassForTemplateLoading方法遇到了加载模板目录的一个小问题. 由于网上的其他论坛,博客写的有点乱,故记录一下. F ...

  8. 补发9.28“天天向上”团队Scrum站立会议

    组长:王森 组员:张金生 张政 栾骄阳 时间:2016.09.28 地点:612寝 组员 已完成 未完成 王森 搭建初步原型 完善原型 张金生 更新UI设计 生成应用界面原型 张政 初步设计框架图 完 ...

  9. 面试问题总结二(技术能力-PHP)----Ⅲ

    42.什么是单点登录? 答:单点登录 SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信 ...

  10. MVC框架理解及优缺点

    MVC:模型(Model).视图(View).控制器(Control) 流程如下: 首先是视图向控制器发送请求,控制器再将业务请求发送给模型, 然后模型处理请求业务并把结果返回给控制器,控制器根据结果 ...