后缀数组中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;}
}

相关内容

热门资讯

造假泛滥、虫入车间、产能拉胯:... 订阅 快刀财经 ▲ 做您的私人商学院世界药房的致命短板。作者:朱末来源:快刀财经(ID:kuai...
影石创新股价“脚踝斩”,刘靖康... 出品|达摩财经近日,第三方数据公司IDC发布了2026年一季度全球手持智能相机行业报告。报告数据显示...
美股半导体股,集体上涨 美股半... 6月29日,美股三大指数集体高开,道指涨0.29%,纳指涨0.96%,标普500指数涨0.55%。 ...
三只*ST股,将摘星脱帽 st... 6月29日晚间,A股三家*ST公司公告称将“摘星脱帽”。 具体来看,*ST艾艾发布关于撤销退市风险警...
【就业创业典型】大棚逐梦人:一... 编者按:近年来,延安市残疾人工作坚持以习近平新时代中国特色社会主义思想为指导,以促进残疾人事业全面高...
公募基金锚定新质生产力,多维赋... 6月22日消息,中国证监会主席吴清近日在2026陆家嘴论坛上表示,资本市场与新质生产力双向奔赴、相互...
液冷服务器概念震荡走强,冰轮环... 6月22日消息,午后液冷服务器概念震荡走强,冰轮环境9天5板,此前康盛股份涨停,大元泵业、川润股份、...
涉留神峪煤矿事故,国家矿山安全... 6月22日消息,国家矿山安全监察局山西局监察执法八处三级调研员耿青禄涉嫌严重违法,涉通洲集团留神峪煤...
周立成拟任中国投资协会秘书长 6月22日消息,中国投资协会发布关于中国投资协会第五届理事会届中调整负责人人选的公示:周立成,男,汉...
以防长称以军已做好对伊采取独立... 据央视新闻,以色列国防部长卡茨日前在与军事记者的闭门谈话中,阐述了以色列在黎巴嫩、伊朗及加沙地带等多...