后缀数组学习

快排的代码很容易理解。

 1  int sa[MAX],temp[MAX],rank[MAX];
 2  int n,k;
 3  bool cmp_sa( int i, int j) {
 4      if(rank[i]!=rank[j])  return rank[i]<rank[j];
 5      else {
 6          int ri= i+k<=n ? rank[i+k] : - 1;
 7          int rj= j+k<=n ? rank[j+k] : - 1;
 8          return ri<rj;
 9     }
10 }
11  void construct_sa( string S, int *sa) {
12     n=S.size();
13      for( int i= 0;i<=n;i++) {
14         sa[i]=i;
15         rank[i]= i < n ? S[i] : - 1;
16     }
17      for(k= 1;k<=n;(k<<= 1)) {
18         sort(sa,sa+ 1+n,cmp_sa) ;
19         temp[sa[ 0]]= 0;
20          for( int i= 1;i<=n;i++) {
21             temp[sa[i]]=temp[sa[i- 1]]+(cmp_sa(sa[i- 1],sa[i])?  1 :  0);
22         }
23          for( int i= 0;i<=n;i++) {
24             rank[i]=temp[i];
25         }
26     }

27 } 

转载于:https://www.cnblogs.com/acvc/p/4159052.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值