后缀数组中height数组的解释
创始人
2025-05-30 05:31:03
0

前文:点我
当我在使用后缀数组中会用到一个数组为heightheightheight
height[i]height[i]height[i]的定义为:排在第iii为的后缀和排在第i−1i-1i−1位的最长公共前缀
并且其应该满足下面这个定理
height[rnk[i]]≥height[rnk[i−1]]−1height[rnk[i]]\geq height[rnk[i-1]]-1 height[rnk[i]]≥height[rnk[i−1]]−1
这个定理的一种证明方法可以参考oi.wikioi.wikioi.wiki:

在这里插入图片描述
但是可以有其他的普通解释:
我们认为字符串是从左开始的,所以i−1i-1i−1位应该在第iii位的左侧,因此i−1i-1i−1位的后缀可以表示成为aAaAaA,第iii位的后缀可以表示成AAA,如果说aAaAaA与排在他前面的后缀SSS的最长公共前缀可以达到kkk位,那么在AAA中是不是一定会有k−1k-1k−1位能与AAA匹配. 那么当这k−1k-1k−1位打头组成后缀时,一定紧邻AAA,如果他们之间不紧邻,则一定有比k−1k-1k−1更长的前缀紧邻AAA,所以至少是k−1k-1k−1.
我们再来看一个字符串

//源串:bdbd
//设i的后缀为dbd
//设i-1的后缀为bdbd
排序:
bd
bdbd//i-1
d
dbd//i

在这个例子里,A=dbdA=dbdA=dbd,并且至少有ddd与dbddbddbd紧邻
根据这个引理可以推导出下面的用法:

void cal_height()
{int k = 0;for (int i = 0; i < n; i++){rank1[sa[i]] = i;}for (int i = 0; i < n; i++){if (rank1[i] == 0)continue;int j = sa[rank1[i] - 1];if (k != 0){k--;}//height[i]>=height[i-1]-1while (i + k < n&&j + k < n&&dp[i + k] == dp[j + k])k++;height[i] = k;}
}

相关内容

热门资讯

坚守价值与风控并行,弘康人寿获... 受长端利率下行及政策鼓励中长期资金入市等因素驱动,2025年险资持续加大对权益资产的配置力度。作为一...
“豆包会和岳云鹏一起讲相声吗”... 01.火山引擎将成为26年春晚独家AI云合作伙伴02.微信辟谣“点击直播链接会被盗号”03.小红书被...
4岁男童突然双眼近视1000度... 近日,郑州大学第一附属医院眼科接诊了一名特殊的小患者。一名4岁男童因经常眯眼、贴脸看电视被父母带到医...
「收盘」A股午后涨幅扩大,41... A股三大股指12月24日集体小幅高开。沪指早盘震荡攀升,深市则高位震荡。午后沪深两市同频上攻,三大股...
产品出海,枢纽联通:摩洛哥投资... 中国商报(记者 赵熠如 文/图)依托特色农产品的出口与世界级枢纽港口的运转,摩洛哥正在转型为跨洲际产...
明年最猛的科技赛道,基本定了!... 12月23日,长征十二号甲火箭发射升空,二级火箭进入预定轨道,但一级箭体未能成功回收。这已经是12月...
南充“密码女王”虚惊一场,浮盈... 文丨郭小兴 编辑丨杜海来源丨正经社(ID:zhengjingshe)(本文约为1600字)人称南充“...
广州市委书记调整 南方+客户端12月24日消息,近日,中央批准:冯忠华同志任广州市委书记;免去郭永航同志的广东省委常委...
茅台全系列产品涨价!飞天茅台再... 中国商报(记者 周子荑)12月24日,中国商报记者从第三方平台“今日酒价”获悉,茅台酒全系列产品市场...
【收盘】A股午后涨幅扩大,41... A股三大股指12月24日集体小幅高开。沪指早盘震荡攀升,深市则高位震荡。午后沪深两市同频上攻,三大股...