后缀自动机题目小结

作为一个傻叉,这两天才学了sam,做了几道题。


先是模版:

//后缀自动机
//SAM
//Suffix Automation


struct State{
    int len;
    State *par,*go[26];
    State(){
    }
};
State *root,*last;
State seq[maxn*2];int seq_cnt;
State *New(int _len){
    State *o=&seq[seq_cnt++];
    memset(o->go,0,sizeof(o->go));o->par=0;o->len=_len;
    return o;
}


void extend(int w){
    State *p=last;
    State *np=New(p->len+1);
    while(p&&p->go[w]==0) p->go[w]=np,p=p->par;
    if(p==0) np->par=root;
    else{
        State *q=p->go[w];
        if(q->len==p->len+1){
            np->par=q;
        }
        else{
            State *nq=New(p->len+1);
            memcpy(nq->go,q->go,sizeof(q->go));
            nq->par=q->par;
            q->par=nq;
            np->par=nq;
            while(p&&p->go[w]==q)
                p->go[w]=nq,p=p->par;
        }
    }
    last=np;
}




void init(){
    seq_cnt=0;root=New(0);last=root;
}


然后是一些题目

poj1509 SAM求最小循环串(后缀自动机)
SPOJ1811最长公共子串问题(后缀自动机)
SPOJ 8222 Substrings(SAM)给一个字符串S,令F(x)表示S的所有长度为x的子串中,出现次数的最大值。求F(1)..F(Length(S))
SPOJ-1812 Longest Common Substring II题意:求多个串的最长公共子串。
SPOJ 7258 SUBLEX (SAM)题目:给出一个串,查询字典序排在第k个的是哪个子串
HDU-4622 Reincarnation 题意:给定一个字符串,长度最长为2000,有至多10000组询问,每个询问给定一个区间,求出该区间内共有多少个不同的子串。
hdu4641 K-string,后缀自动机,并查集
【poj1743】Musical Theme 我们只在意每个节点的right最大值和最小值就行了
【bzoj3676】[Apio2014]回文串 SAM+manacher+倍增
 我们可以发现不同的回文串其实并不多 所以用manacher找出不同的回文串然后sam找对应串就好
还听说了一个奇怪的数据结构回文树(Palindromic Tree)


3926: [Zjoi20150]诸神眷顾的幻想乡 挺有意思的应用 加深了对sam的理解
BZOJ2806(后缀自动机+DP)



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值