bzoj4199: [Noi2015]品酒大会

题面见http://uoj.ac/problem/131

一道后缀数组题

先求出height,然后从大到小枚举每个height。

然后对于每个height值,两端的集合中任意一对后缀的LCP都是这个height。

我们统计答案之后合并两端的集合,用并查集维护即可。

 1 #include<cstdio>
 2 #include<iostream>
 3 #include<cmath>
 4 #include<cstring>
 5 #include<algorithm>
 6 #define maxn 300005
 7 #define inf 1LL<<62
 8 using namespace std;
 9 typedef long long int64;
10 char ch,s[maxn];
11 int n,val[maxn];
12 int64 ans[2][maxn];
13 int fa[maxn],siz[maxn],list[maxn],max_val[maxn],min_val[maxn];
14 int SA[maxn],rank[maxn],height[maxn],sum[maxn],t1[maxn],t2[maxn];
15 bool cmp(int x,int y){
16     if (height[x]!=height[y]) return height[x]>height[y];
17     return x<y;
18 }
19 bool ok;
20 void read(int &x){
21     for (ok=0,ch=getchar();!isdigit(ch);ch=getchar()) if (ch=='-') ok=1;
22     for (x=0;isdigit(ch);x=x*10+ch-'0',ch=getchar());
23     if (ok) x=-x;
24 }
25 void get_SA(){
26     int *x=t1,*y=t2,m=255,tot=0;
27     for (int i=1;i<=n;i++) sum[x[i]=s[i]]++;
28     for (int i=1;i<=m;i++) sum[i]+=sum[i-1];
29     for (int i=n;i>=1;i--) SA[sum[x[i]]--]=i;
30     for (int len=1;tot<n;len<<=1,m=tot){
31         tot=0;
32         for (int i=n-len+1;i<=n;i++) y[++tot]=i;
33         for (int i=1;i<=n;i++) if (SA[i]>len) y[++tot]=SA[i]-len;    
34         for (int i=1;i<=m;i++) sum[i]=0;
35         for (int i=1;i<=n;i++) sum[x[y[i]]]++;
36         for (int i=1;i<=m;i++) sum[i]+=sum[i-1];
37         for (int i=n;i>=1;i--) SA[sum[x[y[i]]]--]=y[i];
38         swap(x,y),x[SA[1]]=tot=1;
39         for (int i=2;i<=n;i++){
40             if (y[SA[i]]!=y[SA[i-1]]||y[SA[i]+len]!=y[SA[i-1]+len]) tot++;
41             x[SA[i]]=tot;    
42         }
43     }
44     for (int i=1;i<=n;i++) rank[i]=x[i];
45 }
46 void get_height(){
47     for (int i=1,j=0;i<=n;i++){
48         if (rank[i]==1) continue;
49         while (s[i+j]==s[SA[rank[i]-1]+j]) j++;
50         height[rank[i]]=j;
51         if (j>0) j--;
52     }    
53 }
54 int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
55 void merge(int x,int y){
56     siz[y]+=siz[x];
57     max_val[y]=max(max_val[y],max_val[x]);
58     min_val[y]=min(min_val[y],min_val[x]);
59     fa[x]=y;    
60 }
61 int main(){
62     read(n);
63     scanf("%s",s+1);
64     get_SA(),get_height();
65     for (int i=1;i<=n;i++) read(val[i]);
66     for (int i=1;i<=n;i++) max_val[i]=val[SA[i]];
67     for (int i=1;i<=n;i++) min_val[i]=val[SA[i]];
68     for (int i=1;i<=n;i++) fa[i]=i;
69     for (int i=1;i<=n;i++) siz[i]=1;
70     for (int i=1;i<n;i++) list[i]=i+1;
71     for (int i=1;i<=n;i++) ans[1][i]=-inf;
72     sort(list+1,list+n,cmp);
73     for (int i=1;i<n;i++){
74         int x=find(list[i]-1),y=find(list[i]);
75         ans[0][height[list[i]]]+=1LL*siz[x]*siz[y];
76         ans[1][height[list[i]]]=max(ans[1][height[list[i]]],1LL*max_val[x]*max_val[y]);
77         ans[1][height[list[i]]]=max(ans[1][height[list[i]]],1LL*max_val[x]*min_val[y]);
78         ans[1][height[list[i]]]=max(ans[1][height[list[i]]],1LL*min_val[x]*max_val[y]);
79         ans[1][height[list[i]]]=max(ans[1][height[list[i]]],1LL*min_val[x]*min_val[y]);
80         merge(x,y);
81     }
82     for (int i=n-2;i>=0;i--) ans[0][i]+=ans[0][i+1],ans[1][i]=max(ans[1][i],ans[1][i+1]);
83     for (int i=0;i<n;i++) printf("%lld %lld\n",ans[0][i],ans[0][i]?ans[1][i]:0);
84     return 0;
85 }

 

转载于:https://www.cnblogs.com/chenyushuo/p/4733941.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/374641.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

css中position初解

positon:static|absolute|relative|fiexd 1、static为默认值&#xff0c;没有定位&#xff0c;元素出现在正常的文档流中&#xff0c;忽略left,right,top,bottom,i-index值。 2、absolute为绝对定位&#xff0c;通过left,top等值对元素进行定位&#xff0c;定位时如果父元素的p…

零XML的Spring配置

Tomasz Nurkiewicz是我们的JCG合作伙伴之一&#xff0c;也是Spring框架的坚定支持者&#xff0c;在他的最新文章中描述了如何在不使用XML的情况下配置Spring应用程序。 注解方法在顶部。 查看他的教程&#xff1a; 没有XML的Spring框架...根本&#xff01; 翻译自: https://ww…

用动画切换按钮的状态

用动画切换按钮的状态 效果 源码 https://github.com/YouXianMing/UI-Component-Collection // // BaseControl.h // BaseButton // // Created by YouXianMing on 15/8/27. // Copyright (c) 2015年 YouXianMing. All rights reserved. //#import <UIKit/UIKit.h> c…

iOS开发之学前了解

学iOS开发能做什么&#xff1f; iOS开发需要学习哪些内容&#xff1f; 先学习什么&#xff1f; 不管你是学习android开发还是iOS开发 都建议先学习UI&#xff0c;原因如下&#xff1a; UI是app的根基&#xff1a;一个app应该是先有UI界面&#xff0c;然后在UI的基础上增加实用功…

力扣gupiao

给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的最大利润。…

Java相当好的隐私(PGP)

公钥加密 这篇文章讨论了PGP或“很好的隐私”。 PGP是常规加密和公用密钥加密的混合实现。 在详细介绍PGP之前&#xff0c;让我们先谈谈公钥加密。 与其他任何加密技术一样&#xff0c;公钥加密解决了通过不安全介质传输安全数据的问题。 即互联网。 结果&#xff0c;该方案的…

HDU 5691 Sitting in Line 状压dp

Sitting in Line题目连接&#xff1a; http://acm.hdu.edu.cn/showproblem.php?pid5691 Description 度度熊是他同时代中最伟大的数学家&#xff0c;一切数字都要听命于他。现在&#xff0c;又到了度度熊和他的数字仆人们玩排排坐游戏的时候了。游戏的规则十分简单&#xff0c…

hello oc

printf("Hello C\n"); //OC可以采用C语言的输出方式 printf("The number is %d\n",100);//%d 输出数字 printf("Hello %s\n","XiaoMing");//%s 输出字符 NSLog("Hello Objective-C"); //采用oc的输出&#xff0c;前面带了一…

Spring3 RESTful Web服务

Spring 3提供了对RESTful Web服务的支持。 在本教程中&#xff0c;我们将向您展示如何在Spring中实现RESTful Web服务 &#xff0c;或者如何将现有的Spring服务公开为RESTful Web服务 。 为了使事情变得更有趣&#xff0c;我们将从上一篇关于Spring GWT Hibernate JPA Infinisp…

zoj 3765 块状链表 OR splay

各种操作o(╯□╰)o...不过都挺简单&#xff0c;不需要lazy标记。 方法1&#xff1a;块状链表 块状链表太强大了&#xff0c;区间操作实现起来简单暴力&#xff0c;效率比splay稍微慢一点&#xff0c;内存开销小很多。 1 #include <iostream>2 #include <cstring>3…

【C#公共帮助类】 Image帮助类

大家知道&#xff0c;开发项目除了数据访问层很重要外&#xff0c;就是Common了&#xff0c;这里就提供了强大且实用的工具。 【C#公共帮助类】 Convert帮助类 Image类&#xff1a; using System; using System.Collections.Generic; using System.Text; using System.IO; usin…

Java泛型快速教程

泛型是Java SE 5.0引入的一种Java功能&#xff0c;在其发布几年后&#xff0c;我发誓那里的每个Java程序员不仅听说过它&#xff0c;而且已经使用过它。 关于Java泛型&#xff0c;有很多免费和商业资源&#xff0c;而我使用的最佳资源是&#xff1a; Java教程 Java泛型和集合…

876. 链表的中间结点

给定一个头结点为 head 的非空单链表&#xff0c;返回链表的中间结点。 如果有两个中间结点&#xff0c;则返回第二个中间结点 代码一&#xff1a; 自己想的一个方法 class Solution {public ListNode middleNode(ListNode head) {ListNode p1 head;ListNode p2 head;//i,j…

Hive查询Join

Select a.val,b.val From a [Left|Right|Full Outer] Join b On (a.keyb.key); 现有两张表&#xff1a;sales 列出了人名及其所购商品的 ID&#xff1b;things 列出商品的 ID 和名称&#xff1a; hive> select * from sales; OK Joe 2 Hank 4 Ali 0 Eve 3 Ha…

jquery 获取easyui combobox选中的值

$(#comboboxlist).combobox(getValue);转载于:https://www.cnblogs.com/ftm-datablogs/p/5526857.html

调度Java应用程序中的主体

许多项目需要计划功能&#xff0c;例如我们计划的工作&#xff0c;重复的工作&#xff0c;异步执行等。 我们的首选方法是使用企业工作调度程序&#xff0c;例如OpenSymphony的Quartz。 使用计划任务进行编码时&#xff0c;最棘手的部分之一是执行部分。 这里的主要经验法则是…

继承映射关系 joinedsubclass的查询

会出现下面这样的错一般是配置文件中的mapping和映射文件中的package路径或者class中的name路径不一致 org.hibernate.MappingException: Unknown entity: com.zh.hibernate.joinedsubclass.Student at org.hibernate.internal.SessionFactoryImpl.getEntityPersister(Sessi…

Spark系列—02 Spark程序牛刀小试

一、执行第一个Spark程序 1、执行程序 我们执行一下Spark自带的一个例子&#xff0c;利用蒙特卡罗算法求PI&#xff1a; 启动Spark集群后&#xff0c;可以在集群的任何一台机器上执行一下命令&#xff1a; /home/spark/spark-1.6.1-bin-hadoop2.6/bin/spark-submit \ --class o…

JVM选项:-client vs -server

您是否曾经在运行Java应用程序时想知道-client或-server开关是什么&#xff1f; 例如&#xff1a; javaw.exe -client com.blogspot.sdoulger.LoopTest也显示在java.exe的“帮助”中&#xff0c;例如&#xff0c;其中的选项包括&#xff1a; -client选择“客户端” VM -serv…

网页前台小知识

1.左右布局div块自适应&#xff0c;首先外边套一个div,把宽度固定一个px&#xff0c;然后margin设为&#xff10; atuo&#xff1b;这样他会根据窗口大小自动变换左右距离&#xff0e;就这么简单&#xff1c;/p> 2.多个标签共用一个样式&#xff0c;用&#xff0c;分隔开 p…