HDU5769-Substring-多校#4-1006-后缀数组
给定一个字符x和一个字符串。要求输出包含此字符的所有不同字串。
后缀数组可以计算一个字符串的所有不同字串,理解了原理就能做这题了。
对于每一个后缀i,将产生len-sa[i]-hight[i]的前缀,累加起来就是所有不同字串。这里要求字串必须包含x
也就是对于每一个后缀i,要减去不含x的前缀。
保存每一个x的位置,用lower_bound查询在此后缀中的第一个x,然后之前的都不计算到贡献当中。
dc3敲起来太慢了
#include <cstdio>
#include <algorithm>
#include <cstring>
#define LL long long
//using namespace std; const int maxn = 1e5+;
#define F(x) ((x)/3+((x)%3 == 1?0:tb))
#define G(x) ((x)<tb?(x)*3+1:((x)-tb)*3+2)
int wa[maxn*],wb[maxn*],wv[maxn*],wss[maxn*]; int c0(int *r,int a,int b)
{
return r[a] == r[b] && r[a+] == r[b+] && r[a+] == r[b+];
}
int c12(int k,int *r,int a,int b)
{
if(k == )
return r[a] < r[b] ||(r[a] == r[b] && c12(,r,a+,b+));
else
return r[a] < r[b] ||(r[a] == r[b] && wv[a+] < wv[b+]);
}
void sort(int *r,int *a,int *b,int n,int m)
{
int i;
for(i=;i<n;i++) wv[i] = r[a[i]];
for(i=;i<m;i++) wss[i] = ;
for(i=;i<n;i++) wss[wv[i]]++;
for(i=;i<m;i++) wss[i] += wss[i-];
for(i=n-;i>=;i--)b[--wss[wv[i]] ] = a[i];
}
void dc3(int *r,int *_sa,int n,int m)
{
int i,j,*rn = r+n;
int *san = _sa+n,ta = ,tb=(n+)/,tbc=,p;
r[n] = r[n+] = ;
for(i=;i<n;i++) if(i% != ) wa[tbc++] = i;
sort(r+,wa,wb,tbc,m);
sort(r+,wb,wa,tbc,m);
sort(r,wa,wb,tbc,m);
for(p=,rn[F(wb[])] = ,i=;i<tbc;i++)
rn[F(wb[i])] = c0(r,wb[i-],wb[i]) ? p-:p++;
if(p < tbc) dc3(rn,san,tbc,p);
else for(i=;i<tbc;i++) san[rn[i]] = i;
for(i=;i<tbc;i++) if(san[i]<tb) wb[ta++] = san[i]*;
if(n%==) wb[ta++] = n-;
sort(r,wb,wa,ta,m);
for(i=;i<tbc;i++) wv[wb[i]=G(san[i]) ] = i;
for(i=,j=,p=;i<ta&&j<tbc;p++)
_sa[p] = c12(wb[j]%,r,wa[i],wb[j]) ? wa[i++]:wb[j++];
for(;i<ta;p++) _sa[p] = wa[i++];
for(;j<tbc;p++) _sa[p] = wb[j++];
}
void da(int str[],int _sa[],int _rank[],int _height[],int n,int m)
{
for(int i=n;i<n*;i++) str[i] = ;
dc3(str,_sa,n+,m);
int i,j,k = ;
for(i=;i<=n;i++) _rank[_sa[i]] = i;
for(i=;i<n;i++)
{
if(k) k--;
j = _sa[_rank[i]- ];
while(str[i+k] == str[j+k]) k++;
_height[_rank[i]] = k;
}
} int T;
int sa[*maxn],hehe[*maxn],rank[maxn],height[maxn];
int x;
char line[*maxn]; void debug(int n)
{
for(int i=;i<=n;i++)
{
printf("sa:%d rank:%d height:%d\n",sa[i],rank[i],height[i]);
}
} int main()
{
//freopen("input.txt","r",stdin);
scanf("%d ",&T);
int cas = ;
while(T--)
{
scanf(" %c %s",&x,line);
int len = strlen(line);
for(int i=;i<len;i++) hehe[i] = line[i];
int ch[maxn],cnt = ;
for(int i=;i<len;i++)
{
if(line[i] == x) ch[cnt++] = i;
}
ch[cnt++] = len;
da(hehe,sa,rank,height,len,);
//debug(len);
LL ans = ;
for(int i=;i<=len;i++)
{
int pos = ch[std::lower_bound(ch,ch+cnt,sa[i]) - ch] - sa[i];
ans += len -sa[i] ;
ans -= std::max(pos,height[i]);
}
printf("Case #%d: %I64d\n",++cas,ans);
}
}
HDU5769-Substring-多校#4-1006-后缀数组的更多相关文章
- Lexicographical Substring Search SPOJ - SUBLEX (后缀数组)
Lexicographical Substrings Search \[ Time Limit: 149 ms \quad Memory Limit: 1572864 kB \] 题意 给出一个字符串 ...
- HDU 4691 Front compression (2013多校9 1006题 后缀数组)
Front compression Time Limit: 5000/5000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Othe ...
- 2016暑假多校联合---Substring(后缀数组)
2016暑假多校联合---Substring Problem Description ?? is practicing his program skill, and now he is given a ...
- 2016多校联合训练4 F - Substring 后缀数组
Description ?? is practicing his program skill, and now he is given a string, he has to calculate th ...
- HDU 4691(多校第九场1006) 后缀数组
...还能多说什么. 眼角一滴翔滑过. 一直以为题意是当前串与所有之前输入的串的LCP...然后就T了一整场. 扫了一眼标程突然发现他只比较输入的串和上一个串? 我心中突然有千万匹草泥马踏过. 然后随 ...
- 牛客网多校训练第一场 I - Substring(后缀数组 + 重复处理)
链接: https://www.nowcoder.com/acm/contest/139/I 题意: 给出一个n(1≤n≤5e4)个字符的字符串s(si ∈ {a,b,c}),求最多可以从n*(n+1 ...
- POJ3693 Maximum repetition substring [后缀数组 ST表]
Maximum repetition substring Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9458 Acc ...
- HDU 5769 Substring 后缀数组
Substring Problem Description ?? is practicing his program skill, and now he is given a string, he h ...
- HDU 5679 Substring 后缀数组判重
题意:求母串中有多少不同的包含x字符的子串 分析:(首先奉上FZU官方题解) 上面那个题就是SPOJ694 ,其实这两个题一样,原理每次从小到大扫后缀sa数组,加上新的当前后缀的若干前缀,再减去重复的 ...
- csu 1305 Substring (后缀数组)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1305 1305: Substring Time Limit: 2 Sec Memory Limi ...
随机推荐
- python面向对象(封装、继承、多态)+ 面向对象小栗子
大家好,下面我说一下我对面向对象的理解,不会讲的很详细,因为有很多人的博客都把他写的很详细了,所以,我尽可能简单的通过一些代码让初学者可以理解面向对象及他的三个要素. 摘要:1.首先介绍一下面向对象 ...
- centos中docker的安装
之前学习docker的时候,是在windows上直接使用可执行文件安装的,最近需要在自己的服务器上安装docker,特此了解了一下如何安装,这里补一下. 小白学Docker之基础篇 小白学Docker ...
- H5 32-百度首页
32-百度首页 新 闻 网 页 贴 吧 知 道 音 乐 图 片 视 频 地 图 百科 文库 hao123 | 更多>> 百度地图带你吃喝玩乐,全心全意为人民服务 把百度设为主页 安装百度卫 ...
- kattis Programming Tutors 给游客与导游匹配(二分+二分图)
题目来源:https://vjudge.net/problem/Kattis-programmingtutors 题意: 有n个游客,n个导游,给出他们的坐标,问你怎么匹配可以使他们最大距离最小 题解 ...
- Consecutive Subsequence CodeForces - 977F (map优化DP)·
You are given an integer array of length nn. You have to choose some subsequence of this array of ma ...
- redis 的使用,及如何使用redis维护数亿人的登录状态
一.redis中几个常用的方法 redis的使用场景移步本文 select db redis 下默认有有16个表,0~15可以通过:select 2 或者 select 11这样的方式切换表 keys ...
- RabbitMQ消息的交换
消息的交换 目录 RabbitMQ-从基础到实战(1)— Hello RabbitMQ RabbitMQ-从基础到实战(2)— 防止消息丢失 1.简介 在前面的例子中,每个消息都只对应一个消费者,即使 ...
- Ajax中文乱码的解决
网上有很多解决Ajax中文乱码的例子,昨晚弄了很久,最终确定一种“确实”有效地方法.首先我有必要说明一下我遇到的情况:有一个注册页面,注册用户填完信息并提交后,页面获得信息并通过java servle ...
- 解决scrapy报错:ModuleNotFoundError: No module named 'win32api'
ModuleNotFoundError: No module named 'win32api' 表示win32api未安装 解决办法: 下载对应python版本的win32api,并安装. 下载地址: ...
- js手机短信验证
贴代码之前,我们先讲一下这里我们用到的技术主要有1个.setInterval(),这个方法可以实现倒计时的效果. css: .weui_btn_disabled.weui_btn_default { ...