noi2015品酒大会(sa)

时间:2021-07-17 21:26:28

用常用的套路,排序之后从大到小插入height,用并查集维护即可。

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
typedef long long ll;
const int maxn=;
const ll inf=1e18;
int n,sa[maxn],H[maxn],ra[maxn],tong[maxn],m,tp[maxn],fa[maxn];
ll ans1[maxn],ans2[maxn],c[maxn];
char s[maxn];
int getfa(int x){return (x==fa[x])?x:fa[x]=getfa(fa[x]);}
void rsort(){
for(int i=;i<=m;++i)tong[i]=;
for(int i=;i<=n;++i)tong[ra[tp[i]]]++;
for(int i=;i<=m;++i)tong[i]+=tong[i-];
for(int i=n;i>=;--i)sa[tong[ra[tp[i]]]--]=tp[i];
}
int cmp(int x,int y,int w){return tp[x]==tp[y]&&tp[x+w]==tp[y+w];}
void pre(){
for(int i=;i<=n;++i)ra[i]=s[i]-'a'+,tp[i]=i; m=;rsort(); for(int w=,p=,i;p<n;w+=w,m=p){
for(p=,i=n-w+;i<=n;++i)tp[++p]=i;
for(i=;i<=n;++i)if(sa[i]>w)tp[++p]=sa[i]-w;
rsort();swap(tp,ra);ra[sa[]]=p=;
for(i=;i<=n;++i)ra[sa[i]]=cmp(sa[i],sa[i-],w)?p:++p;
}
int j,k=;
for(int i=;i<=n;H[ra[i++]]=k)
for(k=k?k-:k,j=sa[ra[i]-];s[i+k]==s[j+k];++k);
}
struct node{
int id,v;
bool operator<(const node&t)const{
return v<t.v;
}
}tmp[maxn];
struct lian{
int l,r;
ll ma,mi,len;
}a[maxn];
void merge(int x,int y,int w){
x=getfa(x);y=getfa(y);
ll t1=max(a[x].ma*a[y].ma,a[x].mi*a[y].mi);
ll t2=max(a[x].ma*a[y].mi,a[x].mi*a[y].ma);
ll t3=min(a[x].ma*a[y].ma,a[x].mi*a[y].mi);
ll t4=min(a[x].ma*a[y].mi,a[x].mi*a[y].ma);
a[x].ma=max(a[x].ma,a[y].ma);
a[x].mi=min(a[y].mi,a[x].mi);
ans1[w]+=a[x].len*a[y].len;
a[x].len+=a[y].len;
fa[y]=x;
ans2[w]=max(ans2[w],max(t1,t2)); }
int main(){
cin>>n;
scanf("%s",s+);
pre();
for(int i=;i<=n;++i){
tmp[i-].id=i,tmp[i-].v=H[i];
}
sort(tmp+,tmp+n);
for(int i=;i<=n;++i)scanf("%lld",&c[i]);
for(int i=;i<=n;++i){
a[i].mi=a[i].ma=c[sa[i]];
a[i].l=a[i].r=i;a[i].len=;
fa[i]=i;
}
//for(int i=1;i<=n;++i)cout<<sa[i]<<' '<<H[i]<<endl;
for(int i=;i<=n;++i)ans2[i]=-inf;
for(int i=n-;i>=;--i){
merge(tmp[i].id-,tmp[i].id,tmp[i].v);
}
for(int i=n-;i>=;--i){
ans1[i]+=ans1[i+];
ans2[i]=max(ans2[i],ans2[i+]);
}
for(int i=;i<=n-;++i){
printf("%lld ",ans1[i]);
if(ans2[i]==-inf)printf("%lld\n",);
else printf("%lld\n",ans2[i]);
}
return ;
}

noi2015品酒大会(sa)的更多相关文章

  1. &lbrack;NOI2015&rsqb;品酒大会&lpar;SA数组&rpar;

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

  2. Luogu2178 NOI2015 品酒大会 SA、并查集

    传送门 感觉题目讲的很不清楚-- 题目意思就是给出一个长度为\(n\)的字符串,求对于\(r=0,1,...,n-1\),求出\(LCP(suffix_p,suffix_q) \geq r\)的无序数 ...

  3. BZOJ 4199&colon; &lbrack;Noi2015&rsqb;品酒大会 &lbrack;后缀数组 带权并查集&rsqb;

    4199: [Noi2015]品酒大会 UOJ:http://uoj.ac/problem/131 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 ...

  4. &lbrack;UOJ&num;131&rsqb;&lbrack;BZOJ4199&rsqb;&lbrack;NOI2015&rsqb;品酒大会 后缀数组 &plus; 并查集

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

  5. 洛谷 P2178 &lbrack;NOI2015&rsqb;品酒大会 解题报告

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

  6. 【BZOJ4199】&lbrack;Noi2015&rsqb;品酒大会 后缀数组&plus;并查集

    [BZOJ4199][Noi2015]品酒大会 题面:http://www.lydsy.com/JudgeOnline/wttl/thread.php?tid=2144 题解:听说能用SAM?SA默默 ...

  7. &lbrack;UOJ&num;131&rsqb;&lbrack;BZOJ4199&rsqb;&lbrack;NOI2015&rsqb;品酒大会

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

  8. &lbrack;NOI2015&rsqb; 品酒大会 - 后缀数组&comma;并查集&comma;STL&comma;启发式合并

    [NOI2015] 品酒大会 Description 对于每一个 \(i \in [0,n)\) 求有多少对后缀满足 LCP 长度 \(\le i\) ,并求满足条件的两个后缀权值乘积的最大值. So ...

  9. BZOJ&lowbar;4199&lowbar;&lbrack;Noi2015&rsqb;品酒大会&lowbar;后缀自动机

    BZOJ_4199_[Noi2015]品酒大会_后缀自动机 Description 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 酒家”和“首席 ...

  10. 洛谷P2178 &lbrack;NOI2015&rsqb;品酒大会 后缀数组+单调栈

    P2178 [NOI2015]品酒大会 题目链接 https://www.luogu.org/problemnew/show/P2178 题目描述 一年一度的"幻影阁夏日品酒大会" ...

随机推荐

  1. S5PV210&lowbar;时钟系统

    1.S5PV210的时钟获得:外部晶振+内部时钟发生器+内部PLL产生高频时钟+内部分频器分频 S5PV210外部有4个W晶振接口,可以根据需要来决定在哪里接晶振.接了晶振之后上电相应的模块就能产生振 ...

  2. Vmware9&period;0打开早期版本报错&colon;this virtual machine’s policies are too old to be run by this version of vmware workstation”

    VMWare从6.0升级到9.0,打开以前的虚拟机报错如下: “this virtual machine’s policies are too old to be run by this versio ...

  3. 数往知来C&num;之 正则表达式 委托 XML&lt&semi;六&gt&semi;

    C# 正则表达式篇 一.正则表达式 正则表达式就是一个字符串,不要想着一下子可以写出一个通用的表达式,先写,不正确再改 写正则表达式就是在找规律 关键字:Regex    -->引入命名空间  ...

  4. CF &num;401 &lpar;Div&period; 2&rpar; E&period; Hanoi Factory &lpar;栈&plus;贪心&rpar;

    题意:给你一堆汉诺塔的盘子,设内半径为a,设外半径为b,高度为h,如果bj ≤ bi 同时bj > ai 我们就认为i盘子能落在在j盘子上,问你最高能落多高 思路:一看题意我们就能想到贪心,首先 ...

  5. (转)Linux命令unzip

    场景:解压war包时候用到该命令,感觉很方便. 1 基本用法 unzip [选项] 压缩文件名.zip 1.2 完整语法 unzip [-cflptuvz] [-agCjLMnoqsVX] [-P & ...

  6. 【代码笔记】Web-CSS-CSS Table&lpar;表格)

    一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  7. js判断访问浏览器是安卓还是ios还是微信浏览器还是微博

    var u = navigator.userAgent, app = navigator.appVersion; var isAndroid = u.indexOf('Android') > - ...

  8. POJ 1094 Sorting It All Out(拓扑排序&plus;判环&plus;拓扑路径唯一性确定)

    Sorting It All Out Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 39602   Accepted: 13 ...

  9. BAT批处理(五)

    批处理程序 一.交互界面设计 没啥说的,看看设计的菜单界面吧:@echo offclstitle 终极多功能修复:menuclscolor 0Aecho.echo ================== ...

  10. 【解决】MongoDB 线上业务处理,数据去重脚本实现

    mongo客户端工具下载  https://robomongo.org/download   线上业务,k线 展示出现问题,相同时间戳的数据多次插入导致数据不真实,后经排查发现是每次都是写的四条数据, ...