P4391 [BOI2009] Radio Transmission 无线传输
题解
KMP算法的应用。
我们知道KMP算法中NEXT数组是当前位置除外的最大前后缀长度。
直接抛出结论:ans=cnt-Next[n]
code
#include<bits/stdc++.h> using namespace std; const int N=1e6+5; int Next[N]; string s; void NEXT(){ int cnt=s.size(); if (cnt==1){ Next[0]=-1; return; } Next[0]=-1; Next[1]=0; int i=1,cn=0; while (i<cnt){ if (s[i]==s[cn]) Next[++i]=++cn; else if (cn!=0) cn=Next[cn]; else Next[++i]=cn; } } int main(){ int l; cin>>l; cin>>s; int cnt=s.size(); NEXT(); cout<<cnt-Next[cnt]<<endl; return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步