题目链接

广义sam+不同子串个数。。

找到所有入度为\(0\)的点开始\(dfs\),建出广义sam。

然后就是不同子串个数

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. using namespace std;
  5. const int MAXN = 1000010;
  6. struct SAM{
  7. int ch[12];
  8. int len, fa;
  9. }sam[MAXN << 1];
  10. int las = 1, cnt = 1, w[MAXN], in[MAXN];
  11. long long f[MAXN << 1];
  12. int len[MAXN], n, m, a, b;
  13. struct Edge{
  14. int next, to;
  15. }e[MAXN << 1];
  16. int head[MAXN], num;
  17. inline void Add(int from, int to){
  18. e[++num].to = to; e[num].next = head[from]; head[from] = num;
  19. }
  20. inline int add(int p, int c){
  21. int np = las = ++cnt;
  22. sam[np].len = sam[p].len + 1;
  23. for(; p && !sam[p].ch[c]; p = sam[p].fa) sam[p].ch[c] = np;
  24. if(!p) sam[np].fa = 1;
  25. else{
  26. int q = sam[p].ch[c];
  27. if(sam[q].len == sam[p].len + 1) sam[np].fa = q;
  28. else{
  29. int nq = ++cnt; sam[nq] = sam[q];
  30. sam[nq].len = sam[p].len + 1;
  31. sam[q].fa = sam[np].fa = nq;
  32. for(; p && sam[p].ch[c] == q; p = sam[p].fa) sam[p].ch[c] = nq;
  33. }
  34. }
  35. return np;
  36. }
  37. void dfs(int u){
  38. f[u] = 1;
  39. for(int i = 0; i < m; ++i)
  40. if(sam[u].ch[i]){
  41. if(!f[sam[u].ch[i]])
  42. dfs(sam[u].ch[i]);
  43. f[u] += f[sam[u].ch[i]];
  44. }
  45. }
  46. void Dfs(int u, int fa, int p){
  47. p = add(p, w[u]);
  48. for(int i = head[u]; i; i = e[i].next)
  49. if(e[i].to != fa)
  50. Dfs(e[i].to, u, p);
  51. }
  52. int main(){
  53. scanf("%d%d", &n, &m);
  54. for(int i = 1; i <= n; ++i)
  55. scanf("%d", &w[i]);
  56. for(int i = 1; i < n; ++i){
  57. scanf("%d%d", &a, &b);
  58. Add(a, b); Add(b, a);
  59. ++in[a]; ++in[b];
  60. }
  61. for(int i = 1; i <= n; ++i)
  62. if(in[i] == 1){
  63. las = 1;
  64. Dfs(i, 0, las);
  65. }
  66. dfs(1);
  67. printf("%lld\n", f[1] - 1);
  68. return 0;
  69. }

【洛谷 P3346】 [ZJOI2015]诸神眷顾的幻想乡(后缀自动机)的更多相关文章

  1. 洛谷P3346 [ZJOI2015]诸神眷顾的幻想乡(广义后缀自动机)

    题意 题目链接 Sol 广义SAM的板子题. 首先叶子节点不超过20,那么可以直接对每个叶子节点为根的子树插入到广义SAM中. 因为所有合法的答案一定是某个叶子节点为根的树上的一条链,因此这样可以统计 ...

  2. [洛谷P3346][ZJOI2015]诸神眷顾的幻想乡

    题目大意:给你一棵$n$个点的树,最多有$20$个叶子节点,问共有几个不同的子串 题解:广义$SAM$,对每个叶子节点深搜一次,每个节点的$lst$设为这个节点当时的父亲,这样就可以时建出来的$SAM ...

  3. bzoj3926: [Zjoi2015]诸神眷顾的幻想乡 后缀自动机在tire树上拓展

    题意:有棵树每个点有个颜色(不超过10种),每个节点不超过20个儿子,问你每两点之间的颜色序列不同的有多少种 题解:先建出树,对于每个叶子节点,bfs一遍建在sam上,每次保留当前点在sam上的位置, ...

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

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

  5. BZOJ 3926: [Zjoi2015]诸神眷顾的幻想乡(后缀自动机)

    传送门 解题思路 因为叶节点不超过\(20\)个,所以可以枚举这些叶节点,并把这些节点当做根扫整棵树.可以证明所有的子串一定可以被便利到,然后可以对这些串建广义后缀自动机.\(dfs\)的时候要记录一 ...

  6. Luogu P3346 [ZJOI2015]诸神眷顾的幻想乡 广义SAM 后缀自动机

    题目链接 \(Click\) \(Here\) 真的是好题啊-不过在说做法之前先强调几个自己总是掉的坑点. 更新节点永远记不住往上跳\(p = fa[p]\) 新建节点永远记不住\(len[y] = ...

  7. P3346 [ZJOI2015]诸神眷顾的幻想乡

    思路 注意到叶子节点(度数为1)只有20个,可以分别以这20个节点为根,把所有子串插入SAM中,统计最后的本质不同的子串个数 所以就是广义SAM了 然后注意要判断一下有无重复插入 代码 #includ ...

  8. BZOJ 3926: [Zjoi2015]诸神眷顾的幻想乡

    3926: [Zjoi2015]诸神眷顾的幻想乡 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1017  Solved: 599[Submit][S ...

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

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

  10. 【BZOJ 3926】 [Zjoi2015]诸神眷顾的幻想乡 (广义SAM)

    3926: [Zjoi2015]诸神眷顾的幻想乡 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 974  Solved: 573 Descriptio ...

随机推荐

  1. 【2019.11.06】SDN上机第2次作业

    参考资料网址:https://www.cnblogs.com/TITIN24/p/11794970.html 利用mininet创建如下拓扑 要求拓扑支持OpenFlow 1.3协议,主机名.交换机名 ...

  2. NoSql数据库Redis系列(5)——Redis主从复制

    前面介绍Redis,我们都在一台服务器上进行操作的,也就是说读和写以及备份操作都是在一台Redis服务器上进行的,那么随着项目访问量的增加,对Redis服务器的操作也越加频繁,虽然Redis读写速度都 ...

  3. golang调用 exec命令 出现too many open files

    systemd 启动的服务, 跟系统的ulimit 没有关系. 大概的意思就是通过systemd启动的服务,不会使用ulimit中的配置,需要在systemd中或者service配置文件中定义,可以通 ...

  4. springcloud添加自定义的endpoint来实现平滑发布

    在我之前的文章  springcloud如何实现服务的平滑发布 里介绍了基于pause的发布方案. 平滑发布的核心思想就是:所有服务的调用者不再调用该服务了就表示安全的将服务kill掉. 另外actu ...

  5. 进行编译时提示'error: unrecognized command line option "-std=gnu11"'如何处理?

    答: 说明编译器不支持此选项,那么在Makefile中替换此选项-std=gnu11 替换成-std=gnu99或-std=c99或-std=c11等,主要看编译器都支持哪些编译选项,笔者的支持-st ...

  6. sqlserver表被锁了,解锁方法,删除锁的方法

    -- 查询死锁select        request_session_id spid,       OBJECT_NAME(resource_associated_entity_id) table ...

  7. EasyRTMP推送扩展支持HEVC(H265) RTMP推送之Metadata结构填写详解

    我们在<EasyNVR摄像机网页直播中,推流组件EasyRTMP推送RTMP扩展支持HEVC(H.265)的方案>中描述了关于EasyRTMP进行RTMP HEVC(H.265)推流的概括 ...

  8. [转]Ubuntu18.04下安装搜狗输入法

    鏈接地址:https://blog.csdn.net/lupengCSDN/article/details/80279177

  9. shell语法学习

    [原文] 菜鸟笔记shell教程学习. 本篇博客只是记录shell的一些关键语法,主要是做一个记录,有些内容也是copy过来的,并不是一个完整的教程,想完整学习shell的同学可以前往 shell脚本 ...

  10. 算法浅谈之DP悬线法

    悬线法 用途 解决给定矩阵中满足条件的最大子矩阵 做法 用一条线(横竖貌似都行)左右移动直到不满足约束条件或者到达边界 定义 \(left[i][j]\):代表从\((i,j)\)能到达的最左位置 \ ...