博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ 2882: 工艺 [后缀自动机+map]
阅读量:6705 次
发布时间:2019-06-25

本文共 1498 字,大约阅读时间需要 4 分钟。

Description

小敏和小燕是一对好朋友。
他们正在玩一种神奇的游戏,叫Minecraft。
他们现在要做一个由方块构成的长条工艺品。但是方块现在是乱的,而且由于机器的要求,他们只能做到把这个工艺品最左边的方块放到最右边。
他们想,在仅这一个操作下,最漂亮的工艺品能多漂亮。
两个工艺品美观的比较方法是,从头开始比较,如果第i个位置上方块不一样那么谁的瑕疵度小,那么谁就更漂亮,如果一样那么继续比较第i+1个方块。如果全都一样,那么这两个工艺品就一样漂亮。

Input

第一行两个整数n,代表方块的数目。
第二行n个整数,每个整数按从左到右的顺序输出方块瑕疵度的值。

Output

一行n个整数,代表最美观工艺品从左到右瑕疵度的值。

题意:最小表示法 只不过字符集无限大

用map就行了
SAM用map比AC自动机好写多了
#include 
#include
#include
#include
#include
using namespace std;const int N=1e6+5;inline int read(){ char c=getchar();int x=0,f=1; while(c<'0'||c>'9'){
if(c=='-')f=-1; c=getchar();} while(c>='0'&&c<='9'){x=x*10+c-'0'; c=getchar();} return x*f;}int n,s[N];map
::iterator it;struct State{ map
ch; int val,par;}t[N];int sz,root,last;inline int nw(int _){t[++sz].val=_;return sz;} inline void iniSAM(){sz=0;root=last=nw(0);}void extend(int c){ int p=last,np=nw(t[p].val+1); while(p&&!t[p].ch[c]) t[p].ch[c]=np,p=t[p].par; if(!p) t[np].par=root; else{ int q=t[p].ch[c]; if(t[q].val==t[p].val+1) t[np].par=q; else{ int nq=nw(t[q].val+1); t[nq].ch=t[q].ch; t[nq].par=t[q].par; t[q].par=t[np].par=nq; while(p&&t[p].ch[c]==q) t[p].ch[c]=nq,p=t[p].par; } } last=np;}int main(){ freopen("in","r",stdin); iniSAM(); n=read(); for(int i=1;i<=n;i++) s[i]=read(),extend(s[i]); for(int i=1;i<=n;i++) extend(s[i]); int u=root; for(int i=1;i<=n;i++){ printf("%d",t[u].ch.begin()->first),u=t[u].ch.begin()->second; if(i!=n) putchar(' '); }}

 

转载地址:http://hiflo.baihongyu.com/

你可能感兴趣的文章
深入浅出JavaScript运行机制
查看>>
LeetCode 272 Closest Binary Tree Traversal II 解题思路
查看>>
video自动播放 隐藏播放控制条,并且用点击 video 元素的时候 控制暂停和播放...
查看>>
代码重构之消除分支结构
查看>>
ingress controller学习记录
查看>>
328. Odd Even Linked List
查看>>
分布式应急响应
查看>>
iso定制封装
查看>>
精通MVC3摘译(8)-处理输出(2)
查看>>
字符串翻转之实现二
查看>>
Windows server 2008 Hyper-v下,玩转office communicator Server 2007 Enterprise
查看>>
内核调优记录file-max
查看>>
RHEL 5基础篇—linux的简介
查看>>
grub启动引导装载程序总结。
查看>>
分布式系统开发的一些相关理论基础——CAP、ACID、BASE
查看>>
ASP.NET 页生命周期概述
查看>>
Xen虚拟机克隆实战
查看>>
HttpContext.Current.Session ,出现未将对象引用设置到实例上
查看>>
所谓深度链接(Deep linking)
查看>>
C#中的数据格式转换 (未完待更新)
查看>>