国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設(shè)計 > 正文

【bzoj1355】 Baltic2009

2019-11-14 10:02:10
字體:
供稿:網(wǎng)友

題意 給定一個字符串A,求最短的字符串B,使得A是若干個B連接成的字符串的前綴 若A=abcabcab 則B=abc

求出A串在KMP算法中A的next數(shù)組 設(shè)A的長度為N 則答案為A的前N-next[N]位 分兩種情況討論: next[N] > N/2 next[N] <= N/2

#include<iostream>#include<cstdio>#include<cstring>#include<string>#include<algorithm>using namespace std;char w[1000005];int n,len_s,len_w,ans,t[1000005];inline void calc_w(){ int j; t[0]=-1; for (int i=0;i<n;i++) { j=t[i]; while(w[i]!=w[j]&j!=-1) j=t[j]; t[i+1]=++j; }}int main(){ cin>>n; scanf("%s",w); calc_w(); for (int i=1;i<=n;i++) cout<<t[i]<<' '; cout<<endl; cout<<n-t[n];}
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 铁力市| 故城县| 嘉峪关市| 新巴尔虎右旗| 永顺县| 金华市| 海宁市| 武胜县| 赣榆县| 化德县| 安西县| 瑞金市| 遵义县| 寻甸| 浦东新区| 峡江县| 沙河市| 皋兰县| 深水埗区| 塔城市| 曲周县| 远安县| 梁平县| 舒兰市| 玛曲县| 三明市| 墨竹工卡县| 大化| 德州市| 望谟县| 三台县| 新巴尔虎右旗| 泗水县| 合阳县| 上思县| 郑州市| 资源县| 青浦区| 桓台县| 周至县| 普陀区|