品酒大会 bzoj-4199 Noi-2015

题目大意:给定一个字符串,如果其两个子串的前$r$个字符相等,那么称这两个子串的开头两个位置$r$相似。如果两个位置勾兑在一起那么美味度为两个位置的乘积。

注释:$1\le length \le 3\cdot 10^5$。


想法:我们先建立后缀自动机。

然后求出后缀树。

显然如果在后缀树上一个节点是另一个节点的祖先,那么这个节点代表的所有字符串一定是另一个节点代表的所有字符串的后缀。

唔....

这个时候我们发现不太对,于是就对反串建好了。

建立出后缀树时候,我们树形$dp$就好了啊。

然后我们求$f[i]$表示恰好$i$相似的方案数。

那么$f[i]$就是$dis$为$i$的子树两两儿子$size$和。

之后$g[i]$就是$dis$为$i$的子树中两个最大的点的乘积。

有个小问题就是权值可能为负所以还要维护最小值和次小值。

最后前缀加和前缀取$max$统计一下即可。

代码

#include <bits/stdc++.h>
#define N 600010
#define MAX (0x7f7f7f7f)
#define MIN (0x80808080)
using namespace std; typedef long long ll;
int w[N],a[N][26],fa[N],dis[N],lst=1,cnt=1,head[N],to[N],nxt[N],tot,size[N],mx[N],mn[N];
ll ans1[N],ans2[N]; char str[N];
inline void add(int x,int y) {to[++tot]=y; nxt[tot]=head[x]; head[x]=tot;}
void update(int c,int v)
{
int p=lst,np=lst=++cnt;
dis[np]=dis[p]+1; mx[np]=mn[np]=v; size[np]=1;
while(p&&!a[p][c]) a[p][c]=np,p=fa[p];
if(!p) {fa[np]=1; return;}
int q=a[p][c];
if(dis[q]==dis[p]+1) {fa[np]=q; return;}
int nq=++cnt;
memcpy(a[nq],a[q],sizeof a[q]); dis[nq]=dis[p]+1;
fa[nq]=fa[q]; fa[np]=fa[q]=nq;
while(p&&a[p][c]==q) a[p][c]=nq,p=fa[p];
}
void dfs(int x)
{
int p=dis[x]; for(int i=head[x];i;i=nxt[i])
{
dfs(to[i]);
ans1[p]+=(ll)size[x]*size[to[i]];
if(mx[x]!=MIN) ans2[p]=max(ans2[p],(ll)mx[x]*mx[to[i]]);
if(mn[x]!=MAX) ans2[p]=max(ans2[p],(ll)mn[x]*mn[to[i]]);
size[x]+=size[to[i]];
mx[x]=max(mx[x],mx[to[i]]); mn[x]=min(mn[x],mn[to[i]]);
}
}
int main()
{
int n; scanf("%d%s",&n,str+1);
memset(mx,0x80,sizeof mx); memset(mn,0x7f,sizeof mn); memset(ans2,0x80,sizeof ans2);
for(int i=1;i<=n;i++) scanf("%d",&w[i]);
for(int i=n;i;i--) update(str[i]-'a',w[i]);
for(int i=2;i<=cnt;i++) add(fa[i],i);
dfs(1); for(int i=n-2;~i;i--) ans1[i]+=ans1[i+1],ans2[i]=max(ans2[i],ans2[i+1]);
for(int i=0;i<n;i++) printf("%lld %lld\n",ans1[i],ans1[i]?ans2[i]:0);
return 0;
}

小结:后缀自动机求出的后缀树还是非常好用的。

[bzoj4199][Noi2015]品酒大会_后缀自动机_后缀树_树形dp的更多相关文章

  1. [UOJ#131][BZOJ4199][NOI2015]品酒大会 后缀数组 + 并查集

    [UOJ#131][BZOJ4199][NOI2015]品酒大会 试题描述 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个 ...

  2. [UOJ#131][BZOJ4199][NOI2015]品酒大会

    [UOJ#131][BZOJ4199][NOI2015]品酒大会 试题描述 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个 ...

  3. [BZOJ4199][Noi2015]品酒大会 树形DP+后缀自动机

    由于要找后缀的前缀,所以先用反串建立SAM. link边组成了后缀树. 两个子串的最长公共前缀是LCA的step 树形dp即可. #include<iostream> #include&l ...

  4. bzoj4199: [Noi2015]品酒大会(后缀数组)

    题目描述 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战 两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个奖项,吸引了众多品酒师参加. 在大会的晚餐上,调酒师 Rainb ...

  5. BZOJ4199 [Noi2015]品酒大会 【后缀数组 + 单调栈 + ST表】

    题目 一年一度的"幻影阁夏日品酒大会"隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发"首席品 酒家"和"首席猎手"两个奖项,吸 ...

  6. bzoj4199: [Noi2015]品酒大会 (并查集 && 后缀数组)

    据说用后缀自动机 + dp也能做 然而并不会 后缀数组的做法呢 就是先建个后缀数组,求出height值,此时如果直接找,复杂度是n ^ 2的,肯定会超时. 但是height大的值是不会对小的产生影响的 ...

  7. [BZOJ4199][NOI2015]品酒大会

    #131. [NOI2015]品酒大会 统计 描述 提交 自定义测试 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个奖项, ...

  8. 并不对劲的bzoj4199: [Noi2015]品酒大会

    传送门-> 又称普及大会. 这题没什么好说的……后缀自动机裸题……并不对劲的人太菜了,之前照着标程逐行比对才过了这道题,前几天刚刚把这题一遍写对…… 这题的输出和某两点相同后缀的长度有关,那么把 ...

  9. 2019.02.28 bzoj4199: [Noi2015]品酒大会(sam+线段树)

    传送门 题意:给一个串,每个位置有一个权值,当S[s...s+len−1]=S[t...t+len−1]&&S[s...s+len]̸=S[t..t+len]S[s...s+len-1 ...

随机推荐

  1. (转)新手学习System Verilog & UVM指南

    从刚接触System Verilog以及后来的VMM,OVM,UVM已经有很多年了,随着电子工业的逐步发展,国内对验证人才的需求也会急剧增加,这从各大招聘网站贴出的职位上也可以看出来,不少朋友可能想尽 ...

  2. javascript动态添加、修改、删除对象的属性与方法

    在其他语言中,对象一旦生成,就不可更改了,要为一个对象添加修改成员必须要在对应的类中修改,并重新实例化,而且程序必须经过重新编译.JavaScript 中却非如此,它提供了灵活的机制来修改对象的行为, ...

  3. EF为什么向我的数据库再次插入已有对象?(ZT)

    最近做了个多对多对实体对象,结果发现每次只要增加一个子实体,就会自动添加一个父实体进去,而不管该父实体是否已经存在. 找了好久,终于找到这篇文章,照文章内容来看,应该是断开连接导致的. 原文地址:ht ...

  4. css-test

    transition-content See the Pen NLOgVR by nakata139@gmail.com (@deepblue1982) on CodePen.

  5. 手把手教你免费把网站IP换成1.1.1.1/1.0.0.1

    近日,Cloudflare官方发文,与APNIC官方合作打算用IP1.1.1.1推出速度更快.私密性更强的DNS Cloudflare 运行全球规模最大.速度最快的网络之一. APNIC 是一个非营利 ...

  6. 【OpenCV】motion blur 的简单实现

    先推荐界面比较丑,但是还不错的在线图片处理网站: http://www168.lunapic.com/editor/ 由于最近在做毕设了,结合前面关于图像处理和机器学习的操作,想做一些好玩的东西,其中 ...

  7. (转)编码剖析@Resource注解的实现原理

    http://blog.csdn.net/yerenyuan_pku/article/details/52860046 上文我们已经学会使用@Resource注解注入属性.学是学会了,但也仅限于会使用 ...

  8. CentOS 7上修改主机名

                                       如何在CentOS 7上修改主机名                                           在Cent ...

  9. win10下安装使用mysql-5.7.23-winx64

    下载MySQLhttps://dev.mysql.com/downloads/file/?id=478884 解压到文件,此例为D盘根目录 在mysql-5.7.23-winx64目录下创建[my.i ...

  10. ignore-on-commit svn 更改文件后 默认不提交文件到服务器(服务器上已存在的文件)

    不用那个忽略文件那个,那个功能是删除服务器的文件,然后本地还存在,不符合我的要求 我的要求是 服务器文件在,我不动,然后我改完了,和别人的不冲突,我也不覆盖别人的文件 主要就是默认不提交,这个很重要 ...