[BZOJ4180] 字符串计数
膜一发KsCla巨佬
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2e5+10;
struct __SAM {
int lst,tot,ch[N][4],prt[N],mxl[N];
void init() {
memset(ch[1],0,sizeof ch[1]);
lst=tot=1;
}
void extend(int c) {
int p=lst,x=lst=++tot; mxl[x]=mxl[p]+1;
while(p&&!ch[p][c]) ch[p][c]=x,p=prt[p];
if(!p) prt[x]=1;
else {
int q=ch[p][c];
if(mxl[q]==mxl[p]+1) prt[x]=q;
else {
int k=++tot;
mxl[k]=mxl[p]+1; prt[k]=prt[q];
prt[q]=prt[x]=k;
memcpy(ch[k],ch[q],sizeof ch[q]);
while(ch[p][c]==q) ch[p][c]=k,p=prt[p];
}
}
}
} SAM;
ll n;
char str[N]; queue<int> Q;
int m,dep[N]; bool vis[N];
struct Mtrx {
ll a[4][4];
ll*operator[](const int&x) {return a[x];}
const ll*operator[](const int&x) const{return a[x];}
ll getMin() {
ll ans=2e18;
for(int i=0; i<m; ++i) ans=*min_element(a[i],a[i]+m);
return ans;
}
Mtrx getPow(ll y) {
if(y==1) return *this;
Mtrx c=*this,x=c; y--;
for(; y; y>>=1,x=x*x) if(y&1) c=c*x;
return c;
}
Mtrx operator*(const Mtrx&b) const{
Mtrx c; memset(&c,0x3f,sizeof c);
for(int i=0; i<m; ++i) for(int k=0; k<m; ++k)
for(int j=0; j<m; ++j) c[i][j]=min(c[i][j],a[i][k]+b[k][j]);
return c;
}
} E;
inline void bfs(int T) {
memset(vis,0,sizeof vis);
dep[SAM.ch[1][T]]=1;
vis[SAM.ch[1][T]]=1;
Q.push(SAM.ch[1][T]);
while(Q.size()) {
int x=Q.front(); Q.pop();
for(int i=0,y; i<m&&(y=SAM.ch[x][i],true); ++i)
if(y&&!vis[y]) Q.push(y),vis[y]=1,dep[y]=dep[x]+1;
else E[T][i]=min(E[T][i],(ll)dep[x]);
}
}
int main() {
SAM.init();
scanf("%lld%s",&n,str);
for(int i=0; str[i]; ++i) {
SAM.extend(str[i]-'A');
m=max(m,str[i]-'A'+1);
}
memset(&E,0x3f,sizeof E);
for(int i=0; i<m; ++i) bfs(i);
ll l=0,r=1e18,mid,ans=0;
while(l<=r) {
mid=(l+r)>>1;
if(E.getPow(mid).getMin()<n) l=mid+1;
else ans=mid,r=mid-1;
}
printf("%lld\n",ans);
return 0;
}
[BZOJ4180] 字符串计数的更多相关文章
- BZOJ4180:字符串计数(SAM,二分,矩阵乘法)
Description SD有一名神犇叫做Oxer,他觉得字符串的题目都太水了,于是便出了一道题来虐蒟蒻yts1999. 他给出了一个字符串T,字符串T中有且仅有4种字符 'A', 'B', 'C', ...
- 【BZOJ-4180】字符串计数 后缀自动机 + 矩阵乘法
4180: 字符串计数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 146 Solved: 66[Submit][Status][Discuss] ...
- 【BZOJ 4180】 4180: 字符串计数 (SAM+二分+矩阵乘法)
4180: 字符串计数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 164 Solved: 75 Description SD有一名神犇叫做Oxe ...
- bzoj 4180: 字符串计数
Description SD有一名神犇叫做Oxer,他觉得字符串的题目都太水了,于是便出了一道题来虐蒟蒻yts1999. 他给出了一个字符串T,字符串T中有且仅有4种字符 'A', 'B', 'C', ...
- Codeword CodeForces - 666C (字符串计数)
链接 大意:求只含小写字母, 长度为n, 且可以与给定模板串匹配的字符串个数 (多组数据) 记模板串为P, 长为x, 总串为S. 设$f_i$为S为i时的匹配数, 考虑P最后一位的首次匹配位置. 若为 ...
- 「bzoj 4180: 字符串计数」
题目 真是一道好题 首先根据一个非常显然的贪心,如果给出了一个串\(S\),我们如何算最小操作次数呢 非常简单,我们直接把\(S\)拉到\(T\)的\(SAM\)上去跑,如果跑不动了就停下来,重新回到 ...
- Codeforces Beta Round #17 C. Balance (字符串计数 dp)
C. Balance time limit per test 3 seconds memory limit per test 128 megabytes input standard input ou ...
- BZOJ 4180: 字符串计数 后缀自动机 + 矩阵乘法 + 二分(神题)
Description SD有一名神犇叫做Oxer,他觉得字符串的题目都太水了,于是便出了一道题来虐蒟蒻yts1999. 他给出了一个字符串T,字符串T中有且仅有4种字符 'A', 'B', 'C ...
- BZOJ.4180.字符串计数(后缀自动机 二分 矩阵快速幂/倍增Floyd)
题目链接 先考虑 假设S确定,使构造S操作次数最小的方案应是:对T建SAM,S在SAM上匹配,如果有S的转移就转移,否则操作数++,回到根节点继续匹配S.即每次操作一定是一次极大匹配. 简单证明:假设 ...
随机推荐
- 未关闭虚拟机直接关闭vmware引发的一系列问题——Windows下linux虚拟机
虚拟机长时间挂起重新打开时卡顿,无法开启,脑抽直接关闭了vmware软件引起的一系列问题. 原因是关闭了vmware,但是相应的虚拟机并没有关闭,所以虚拟机不能重开 会出现如下提示 解决方案如下: 1 ...
- 修改 Idea 终端 Terminal 为 GitBash
Terminal "C:\Program Files\Git\bin\sh.exe" -login -i
- Android_(控件)使用ImageView简单实现图片翻转
效果图 1)可以把图像的id存放数组中,利用setImageResource()或setImageDrawable()方法(放在数组中便于循环) 2)已经是第一张图像时,再点击“上一页”,应Toast ...
- IDEA无法通过类加载器获取resources文件夹配置文件解决办法
问题描述:如果IDEA无法通过类加载器获取resources文件夹配置文件,一定是Classpath编译文件没有导致的. 1.在通过配置文件来获取文件信息时,在resouces文件中放入了filena ...
- Java 实现 2的次幂表示
问题描述 任何一个正整数都可以用2进制表示,例如:137的2进制表示为10001001. 将这种2进制表示写成2的次幂的和的形式,令次幂高的排在前面,可得到如下表达式:137=2^7+2^3+2^0 ...
- POJ 3128 Leonardo's Notebook (置换)
Leonardo's Notebook Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2324 Accepted: 98 ...
- LeetCode 80. 删除排序数组中的重复项 II(Remove Duplicates from Sorted Array II)
题目描述 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成 ...
- Forcepoint
Forcepoint One Endpoint Diagnostics Tool C:\Program Files\Websense\Websense Endpoint\WEPDiag.exe &qu ...
- java加密算法相关
简介 RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest).阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的.1987年首次公布,当 ...
- import 和 require 的 区别
node编程中最重要的思想就是模块化,import和require都是被模块化所使用. 遵循规范 require 是 AMD规范引入方式 import是es6的一个语法标准,如果要兼容浏览器的话必须转 ...